class Solution {
public:
    int NumberOf1Between1AndN_Solution(int n)
    {
        if(n==0) return 0;
        vector<int> number;
        while(n!=0) number.push_back(n),n/=10;
        
        int res=0;
        for(int i=number.size()-1;i>=0;i--)
        {
            int left=0,right=0,t=1;
            for(int j=number.size()-1;j>i;j--) left = left*10+number[j];
            for(int j=i-1;j>=0;j--) right = right*10 + number[j],t*=10;
            res+=left*t;
            if(number[i]==1) res += right + 1;
            else if(number[i]>1) res += t;
        }
        
        return res;
    }
};
2020-05-14
在牛客打卡22天,今天学习:刷题 2 道/代码提交 2 次
全部评论

相关推荐

一名愚蠢的人类:多少games小鬼留下了羡慕的泪水
投递荣耀等公司10个岗位
点赞 评论 收藏
分享
勤奋努力的椰子这就开摆:美团骑手在美团工作没毛病
投递美团等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务