20200818-数1的个数(奥赛一本通 P69 5)

//给定一个十进制正整数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"

#include <bits/stdc++.h>
using namespace std;
int main()
{
  int n,a;
  int box=0;
  cin>>n;
  for(int i=1;i<=n;++i)
    {
      a=i;
      do
        {
          if(a%10==1)
          {
            box++;
          }
         a=a/10;
         } while(a!=0);
    }
  cout<<"总个数为:"<<box<<endl;
  return 0;
}

posted @ 2020-08-18 19:36  财盛  阅读(152)  评论(0编辑  收藏  举报