算法训练 1的个数

资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
  输入正整数n,判断从1到n之中,数字1一共要出现几次。例如1123这个数,则出现了两次1。例如15,那么从1到15之中,一共出现了8个1。
输入格式
  一个正整数n
输出格式
  一个整数,表示1出现的资料
样例输入
15
样例输出
8
数据规模和约定
  n不超过30000

#include 
//求一个数的数字1出现的次数
int ans(int i){
	int count=0;
	for(;i!=0;i/=10){
		if(i%10==1)
			count++;
	}
	/*while(i!=0){
		if(i%10==1)
			count++;
		i/=10;
	}*/
	return count;
}
int main(){
	int n;
	scanf("%d",&n);
	int i;
	int count=0;
	for(i=1;i<=n;i++){
		count+=ans(i);
	}
	printf("%d",count);
	return 0;
}```

你可能感兴趣的:(蓝桥杯,算法)