问题:输入一个正整数N,求1到N之间的所有整数中所出现的1的个数。
举例来说:
N为3,1、2、3中只有一个1存在;
N为12,1、2、3、4、5、6、7、8、9、10、11、12中有五个1存在
方法一
最简单的方法就是遍历1到N,求出每个数中含有的”1”的个数,再相加,就得到了所求。方法二
假设N为一个四位数abcd,a、b、c、d分别是N的各个数位上的数字。假设我们要求百位上回出现的“1”的个数,它可能会受到百位上数字(b)、百位以下(cd)、百位以上(a)数字的影响。因为要求的是“1”的个数,如果百位数字b为0,则结果由百位以上数字决定,假设数字N为7077,则百位出现“1”的情况有100-199、1100-1199、…、6100-6199,共7*100个;
如果百位数字b为1,则结果由百位以上和百位以下数字决定,假设数字N为7177,则百位出现“1”的情况有100-199、1100-1199、…、6100-6199、7100-7177,共7*100+(77+1)个;
如果百位数字b大于1,则结果由百位以上数字决定,假设数字N为7277,则百位出现“1”的情况有100-199、1100-1199、…、6100-6199、7100-7199,共(7+1)*100个,
综上,代码如下:
#include <iostream>
#include <cstring>
using namespace std;
int sumOfOne(int N)
{
int cnt = 0;
int factor = 1;
int lowerNum = 0, curNum = 0, higherNum = 0;
while(N / factor != 0){
lowerNum = N - (N/factor)*factor;
curNum = (N / factor) % 10;
higherNum = (N / factor) / 10;
if(curNum == 0){
cnt += higherNum * factor;
}
else if(curNum == 1){
cnt += higherNum * factor + lowerNum + 1;
}
else{
cnt += (higherNum + 1) * factor;
}
factor *= 10;
}
return cnt;
}
int main()
{
int N = 1001;
int res = sumOfOne(N);
cout << res << endl;
return 0;
}