问题标题: 酷町堂:1023 “1”见钟情

1
0
已解决
李牧晓
李牧晓
中级天翼
中级天翼

题目描述 Description

给定一个十进制正整数n,写下从1到n的所有整数,然后数一下其中出现的数字“1”的个数。

例如当n=2时,写下1,2。这样只出现了1个“1”;当n=15时,写下1,2,3,4,5,6,7,8,9,10,11,12,13,14,15。这样出现了8个“1”。

输入描述 Input Description

正整数n。1 <= n <= 10000。

输出描述 Output Description

一个正整数,即“1”的个数。

样例输入 Sample Input

15

样例输出 Sample Output

8

很急


0
已采纳
甄子烨
甄子烨
高级光能
高级光能

尽管我有一次CE.....

不过我还是肝出了这一题!

我没啥时间了,直接给核心吧!

先在外面定义一个函数,用来计数,也就是:

int Count(int n){

int count = 0;

while(n){

count += (n % 10 == 1)?1:0;

n = n / 10;

}

return count;

}

主函数,用个while:

count = 0;

for(i = 1;i <= n;i++){

count += Count(i);

}

cout<<count;

快踩我!

 

 

0
0
0
0
张程阳
张程阳
新手天翼
新手天翼

for(int i=1;i<=n;i++){ t=i; while(t){ if(t%10==1){ cnt++; } t/=10; } }

0
张程阳
张程阳
新手天翼
新手天翼

for(int i=1;i<=n;i++){ t=i; while(t){ if(t%10==1){ cnt++; } t/=10; } }

我要回答