【题目描述】
给定一个十进制正整数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<iostream>
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<<sum<<endl;
return 0;
}
信息学奥赛一本通T1095:循环嵌套 数1的个数 归属于 循环嵌套,更多同类题解源程序见:循环嵌套 和 数1的个数
0 篇文章
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!