题目详情
这道题跟之前做的蓝桥杯的 "门派制作 " 简直异曲同工!
重点就是如何得到各个位数的数字:砍掉末尾数字继续循环判断(m/=10)
#include<stdio.h>
int main(){
int i,x,s=0;
long long int n;//给的n的数据范围还挺大,我就范围广一点。
scanf("%lld%d",&n,&x);
for(i=1;i<=n;i++){
int m = i;
//用m来存i的值,以免影响i的循环运算
while(m)
{
if(m % 10 == x)//求余数,可以得到每一位的数值
{
s++;
}
m /= 10;//砍掉末尾数字继续循环
//如:123算出余数3后,砍掉3得到12,继续算出余数2,以此类推...
}
}
printf("%d",s);
return 0;
}
over
如有错误,欢迎指出!
写作不易,如果这篇文章对你有帮助的话,请一键三连哦!

这篇博客介绍了洛谷P1980计数问题的解决思路,通过C语言实现。文章提到该问题与蓝桥杯的'门派制作'题相似,关键在于迭代过程中不断移除数字的个位并进行判断(m /= 10)。作者鼓励读者检查其代码并提供反馈,同时希望对读者有所帮助。
880

被折叠的 条评论
为什么被折叠?



