博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA - 1225 Digit Counting
阅读量:5267 次
发布时间:2019-06-14

本文共 1317 字,大约阅读时间需要 4 分钟。

//法一://收获:这题对于各位的统计,也没什么特别的技巧,不过是取余;但是,if-else从最高数位开始找,可以有效地避免取余得到的前置0被多余统计;而事实上,其实也根本不会出现多余统计的情况,因为这个选择语句,已经确定了到底有几位,无用的根本没分离,分离出的都是一定要统计的#include 
#include
using namespace std;int main(){ int a[10], t, n; cin >> t; while (t--) { cin >> n; memset(a, 0, sizeof(a)); for (int i = 1; i <= n; i++) { if (i == 10000) { a[1]++; a[0] += 4; } else if (i / 1000) { a[i / 1000]++; a[i / 100 % 10]++; a[i / 10 % 10]++; a[i % 10]++; } else if (i / 100) { a[i / 100]++; a[i / 10 % 10]++; a[i % 10]++; } else if (i / 10) { a[i / 10]++; a[i % 10]++; } else a[i]++; } for (int i = 0; i < 10; i++) { if (i) cout << " "; cout << a[i]; } cout << endl; } return 0;}

//法2:其实无非就是用sprintf再写了一次//不得不说,有时候学到一个新函数的用法,真的是能让代码变简洁好多,一个个写选择真的很繁琐...#include 
#include
#include
using namespace std;int main(){ int a[10], t, n, len; char s[10]; cin >> t; while (t--) { cin >> n; memset(a, 0, sizeof(a)); for (int i = 1; i <= n; i++) { sprintf(s, "%d", i); len = strlen(s); for (int j = 0; j < len; j++) a[s[j] - '0']++; } for (int i = 0; i < 10; i++) { if (i) cout << " "; cout << a[i]; } cout << endl; } return 0;}

转载于:https://www.cnblogs.com/mofushaohua/p/7789489.html

你可能感兴趣的文章
修复IE不能执行JS的方法
查看>>
程序员究竟该如何提高效率zt
查看>>
希尔排序法(缩小增量法)
查看>>
PHP编程基础学习(一)——数据类型
查看>>
MongoDB-JAVA-Driver 3.2版本常用代码全整理(2) - 查询
查看>>
NPOI处理Word文本中上下角标
查看>>
Android笔记 Handler
查看>>
如何阅读大型前端开源项目的源码(转)
查看>>
java.util.Arrays类详解
查看>>
idea搭建tocmat
查看>>
NYOJ-626-intersection set(二分查找)
查看>>
项目管理之路(1):初步踏入项目管理
查看>>
Java 中 静态方法与非静态方法的区别
查看>>
echarts饼图显示百分比
查看>>
JMS消息
查看>>
Jenkins+ProGet+Windows Batch搭建全自动的内部包(NuGet)打包和推送及管理平台
查看>>
php上传文件及头像预览
查看>>
大四java实习生的一些经历
查看>>
线程池的概念
查看>>
Oracle_Statspack性能诊断工具
查看>>