|  | 
 
| 
题目描述
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  输入一个正整数n
 ,试计算从1到n
 的所有整数中,出现1的次数有多少?例如当n=12
 时,有1,2,3,4,5,6,7,8,9,10,11,12,一共出现了5个1。
 
 输入描述
 输入一个正整数n
 (1≤n≤10000
 )。
 
 输出描述
 输出一个整数,即出现1的次数。
 
 复制代码#include<stdio.h>
int main()
{
    int n,a,s=0;scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        while(i>0)
        {
            a=i%10;
            if(a==1){s++;}
            i=i/10;
        }
    }
    printf("%d",s);
}
这段代码的问题在于,在第二个while循环中,它修改了变量i的值,导致后面的循环出现问题。可以使用一个临时变量来存储i的值,而不是直接修改i的值。以下是修改后的代码:
 
 复制代码#include <stdio.h>
int main()
{
    int n, a, s = 0;
    scanf("%d", &n);
    for (int i = 1; i <= n; i++)
    {
        int temp = i; // 临时变量
        while (temp > 0)
        {
            a = temp % 10;
            if (a == 1)
            {
                s++;
            }
            temp = temp / 10;
        }
    }
    printf("%d", s);
    return 0;
}
 这段代码应该可以正确地计算出从1到n的所有整数中,出现1的次数有多少。
 | 
 |