数1的个数(信息学奥赛一本通-T1095)

【题目描述】

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

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

【输入】

正整数n。1 ≤ n ≤ 10000。

【输出】

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

【输入样例】

12

【输出样例】

5

【源程序】

#include
using namespace std;
int main()
{
    int n,sum=1;
    int i,j;

    cin>>n;
    for(i=2; i<=n; i++) //从2开始枚举
        for(j=i; j>0; j/=10) //分离个位
            if(j%10==1)	sum++;//若个位为1,计数器+1

    cout<

 

你可能感兴趣的:(#,信息学奥赛一本通,#,C++语言基础——循环结构)