以十位数为例介绍思路

  • 每100个数里面有10个数的十位为1, 也就是 (n/100)*10
  • 除去整百之后(即n%100),剩下的分三种情况:(1)十位数大于1,那么还有10个数的十位为1;(2)十位数为1,那么还有(个位数+1)个数的十位为1;(3)十位数为0,那么没有十位为1的数

上述分析也可以类比到其他数位。
程序如下

public class Solution {
    public int NumberOf1Between1AndN_Solution(int n) {
        int count = 0;
        int a, b, c;
        for (int m = 1; m <= n; m *= 10) {
            a = n / (10 * m);
            b = n % (10 * m) / m;
            c = n % m;
            count += a * m + (b > 1 ? m : (b == 1 ? c + 1 : 0));
        }
        return count;
    }
}