输出整数各位数字 (15分)

本题要求编写程序,对输入的一个整数,从高位开始逐位分割并输出它的各位数字。
输入格式:
输入在一行中给出一个长整型范围内的非负整数。
输出格式:
从高位开始逐位输出该整数的各位数字,每个数字后面有一个空格。
输入样例:
123456
输出样例:
1 2 3 4 5 6

方法一:

#include<stdio.h>
int main(){
	int n, t;
    int m=1;
    scanf("%d", &n);
    t = n;
    
    while(t/10 != 0){
    	
        m *= 10;
        t /= 10;         //如果n为123,经过此循环,m为100,t为1
    }
    while(m!=0){
    	
        printf("%d ", n/m);     //123/100=1
        n %= m;                 //123%100=23
        m /= 10;                //100/10=10
    }							//接下来继续循环,直到m==0

    return 0;
} 
  • 22
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言参考答案汇总(浙江大学城市学院) 第2周(M2) 2 20011求华氏温度100°F对应的摄氏温度。 2 20012 求华氏温度 150°F 对应的摄氏温度。 3 20013求摄氏温度26°C对应的华氏温度。 3 20015当n为152时,别求出n的个位数字(digit1)、十位数字(digit2)和百位数字(digit3)的值。 3 20026 输入2个整数 num1 和 num2,计算并输出它们的和、差、积、商与余数。 4 第3周(M3) 5 20031 求1+2+3+......+100(调试示例error02_5) 5 20032 求m+(m+1)+(m+2)+......+100 5 20033 求1/m+1/(m+1)+1/(m+2)+......+1/n 6 20034 求1 + 1/3 + 1/5 + ......的前n项和 7 20035 求1-1/4+1/7-1/10+……的前n项之和 7 20036 输出华氏-摄氏温度转换表(改错题error02_6) 8 20038 求x的n次幂 9 20041 生成 3 的乘方表 10 20044 求100^0.5+101^0.5+……+1000^0.5 10 20053 计算物体自由下落的距离 11 20056 计算段函数 11 20061 阶梯电价 12 20062 求m*m+1/m+(m+1)*(m+1)+1/(m+1)+(m+2)*(m+2)+1/(m+2)+......+n*n+1/n 13 20063 求1-2/3+3/5-4/7+5/9-6/11+…… 14 20064 求2^1+2^2+2^3+……+2^n 15 第4周(M4) 15 10007 显示图案 (复习printf()的字符串输出15 20042 生成阶乘表 16 20043 使用函数求 n! /(m!* (n-m)!) 16 20054 求平均值 17 20057 求1+1/2+1/3+......+1/n 18 20065 求0!+1!+2!+……+n! 18 40015 求最小值 19 40018 求a+aa+aaa+aa…a 20 第5周(M5) 21 30001 求一元二次方程的根 21 30002 求段函数的值 23 30003 类统计字符 23 30004 显示五级记制成绩所对应的百制成绩区间(使用switch) 24 30005 显示水果的价格(使用switch) 25 30007 求三角形的面积和周长 27 30008 计算个人所得税 28 30051 判断闰年 29 30052 统计学生平均成绩与及格人数 30 30053 段计算水费(使用嵌套的if-else语句) 31 第6周(M6) 32 40011 求最小公倍数和最大公约数(调试示例error04_1) 32 40012 求1-1/4+1/7-1/10+1/13-1/16+…… 33 40014 求整数的位数 34 40023 换硬币 35 40024 找出各位数字的立方和等于它本身的数 36 40025 找完数(改错题error04_2) 38 40027 从高位开始逐位输出一个整数的各位数字(选作) 39 40052 判断素数 40 40053 逆序输出整数 41 40054 输出斐波那契序列 42 第7周(M7) 42 50002 使用函数判断数的符号 42 50003 使用函数求奇数和 43 50005 使用函数统计素数并求和 44 50006 使用函数统计一个整数数字的个数 45 50007 使用函数找水仙花数 46 50009 使用函数求余弦函数的近似值 48 50052 使用函数找最大值 49 50062 使用函数输出指定范围内的 Fibonacci 数 50 50063 使用函数找出指定范围内的完数 51 第8周(M8) 52 40013 求奇数和 52 40062 求x+x*x/2!+x*x*x/3!+x*x*x*x/4!+……的值 53 50004 使用函数计算两点间的距离 54 50061 使用函数求a+aa+aaa+aa…a 55 60002 整数的十进制、八进制和十六进制表现形式 56 60003 类统计字符 57 60006 验证歌德巴赫猜想 58 60007 使用函数输出整数的逆序数 59 60009 统计单词 60 60062 简单计算器 61
### 回答1: 可以使用循环和取模运算来实现从低位开始逐位割一个非负整数,并输出它的各位数字。具体步骤如下: 1. 读入一个非负整数num; 2. 如果num等于,则直接输出; 3. 循环执行以下步骤,直到num等于: 1) 取num除以10的余数,即num%10,得到num的个位数字; 2) 输出num的个位数字; 3) 将num除以10,即num=num/10,去掉num的个位数字,得到剩余的数字; 4. 程序结束。 下面是一个示例程序: #include <stdio.h> int main() { int num, digit; printf("请输入一个非负整数:"); scanf("%d", &num); if (num == ) { printf("\n"); } else { printf("割结果为:"); while (num > ) { digit = num % 10; printf("%d ", digit); num = num / 10; } printf("\n"); } return ; } 输入一个非负整数,程序会输出它的各位数字,例如: 请输入一个非负整数:12345 割结果为:5 4 3 2 1 注意,输出数字是从低位开始逐位割的,因此需要先输出个位数字,再输出十位数字,以此类推。 ### 回答2: 这道题目要求编写一个程序,对于输入的非负整数,从低位开始逐位割并输出它的各位数字。我们可以使用循环语句实现这个过程。 将输入整数保存在变量n中,我们可以用取余运算一位一位地取出整数的各个数字,并将其输出。具体的方法是,每次将n对10进行取余运算,将得到的余数存储在变量digit中,然后将n除以10,这样就可以将原数的最低位去掉。将digit输出即可得到原数的一位数字。接下来,再次进行循环,直到n等于0为止,这样就能将整个数割开来,逐位输出数字。 以下是实现这个过程的Python代码: n = int(input("请输入一个非负整数:")) while n > 0: digit = n % 10 print(digit) n = n // 10 例如,如果输入数字12345,程序将输出: 5 4 3 2 1 这说明程序已经成功地将数字割开来,并逐位输出了它的各个数字。这个程序思路简单,代码量小,但功能实用,能够帮助我们更好地理解整数的结构和运算规则,也有助于我们掌握编程语言的基本语法和循环控制结构。 ### 回答3: 这个问题需要我们使用编程语言来解决。我们可以使用循环来迭代非负整数的每一位,然后输出这个数字。 首先,我们需要在程序中输入非负整数。我们可以使用Python中的input()函数来实现。例如: ``` n = int(input("请输入一个非负整数:")) ``` 接下来,我们可以使用while循环来逐位割这个数字。我们可以使用取模运算(%)和整除运算(//)来得到数字的每一位。例如: ``` while n > 0: digit = n % 10 print(digit) n = n // 10 ``` 在每一次循环中,我们通过取模运算得到最低位的数字,然后将它打印出来。接着,我们使用整除运算舍弃最低位的数字,得到次低位的数字。循环一直持续到数字割为0为止。 最终,我们得到的完整程序如下所示: ``` n = int(input("请输入一个非负整数:")) while n > 0: digit = n % 10 print(digit) n = n // 10 ``` 通过这个程序,我们可以方便地对一个非负整数进行逐位割并输出它的各位数字

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值