前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【剑指offer】31.整数中1出现的次数

【剑指offer】31.整数中1出现的次数

作者头像
AI那点小事
发布2020-07-21 10:18:56
3500
发布2020-07-21 10:18:56
举报
文章被收录于专栏:AI那点小事

题目

求出1 ~ 13的整数中1出现的次数,并算出100 ~ 1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。


分析

github链接:JZ31-整数中1出现的次数


C++代码

代码语言:javascript
复制
#include <iostream>
using namespace std;

class Solution {
	public:
	    int NumberOf1Between1AndN_Solution(int n){
			int m = n;
			int base = 1;
			int x;
			int ans = 0; 
			while(m){
				x = m % 10;
				m /= 10;
				ans += m*base;
				if(x == 1){
					ans += (n % base) + 1;
				}else if( x > 1){
					ans += base;
				}
				base *= 10;
			}
			return ans;
	    }
};

int main()
{
	int n;
	while(cin>>n){
		Solution s;
		cout<<s.NumberOf1Between1AndN_Solution(n);
	}
	
	return 0;
 } 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 分析
  • C++代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档