判断一个整型数据有几位

判断一个整型数据有几位v1.0

从键盘输入一个整型数据(int型),编写程序判断该整数共有几位。例如,从键盘输入整数16644,该整数共有5位。

程序运行结果示例1:
Please enter the number:
21125↙
21125: 5 bits

程序运行结果示例2:
Please enter the number:
-12234↙
-12234: 5 bits

输入格式: “%d”

输出格式:
输入提示信息:“Please enter the number:\n”
判断该整数共有几位: “%d: %d bits\n”

代码

#include<stdio.h>
int main()
{
    int num,c,sum;
    int i=0;
    printf("Please enter the number:\n");
    scanf("%d",&num);
    while(1)
    {
        c/=10;
        i++;
        sum=i;
        if(c/10==0)
        break;
    }
    printf("%d: %d bits\n",num,sum);
    return 0;
}

思路

1.首先输入一个数字
2.输入计算位数的代码;
3.再添加循环,while(1)——意思为:如果为真。
4.因为num要参与循环,最后输入也要num,固num值会变化,于是我们可以 取一个c=num,代替num去参与循环。

### 回答1: 题目要求编写一个程序,从键盘输入一个整型数据,使用switch语句和循环语句判断整数几位数,并输出包含各个数字的个数。例如,从键盘输入整数16644,该整数共有5位,并且包含1个数字1、1个数字6、2个数字4。 ### 回答2: 题目要求输入一个整型数据,并判断其有几位,再输出包含各个数字的个数。具体实现可以运用循环语句和switch语句。以下是一个可能的代码实现: ```c++ #include <iostream> using namespace std; int main() { int num; int digits[10] = {0}; int count = 0; cout << "请输入一个整数:" << endl; cin >> num; /* 用循环语句计算整数共有几位 */ if (num < 0) { num = -num; } do { int digit = num % 10; // 用取余操作取出最低位 digits[digit]++; // 统计各个数字的个数 count++; // 总位数加1 num /= 10; // 整数右移一位 } while (num > 0); cout << "该整数共有" << count << "位。" << endl; for (int i = 0; i < 10; i++) { if (digits[i] > 0) { cout << i << "的个数为:" << digits[i] << endl; } } return 0; } ``` 解释: 1. 首先定义一个整型变量 `num`,用于存储从键盘输入的整数。同时定义一个长度为10的数组 `digits`,用于记录各个数字的个数。还定义一个变量 `count`,用于记录整数的总位数。 2. 通过 `cin` 输入整数。 3. 为了计算整数位数,使用 `do-while` 循环语句遍历整数的各个位。首先判断整数是否为负数,如果是则取其相反数以便处理。然后每次取出最低位的数字,用数组 `digits` 统计各个数字的个数,并让变量 `count` 加1。最后将整数右移一位,丢掉最低位。 4. 循环结束后,输出总位数以及各个数字的个数。这里用一个 `for` 循环遍历数组 `digits`,输出个数不为零的数字。 总体来说,这是一道不算太难的题目,关键是熟练掌握循环语句和switch语句的应用,以及数组的使用。 ### 回答3: 如何判断一个整型数据几位? 我们可以用一个循环不断除以10,每除一次就把位数加1,直到数值小于10为止。如下所示: ``` int num = 16644; int count = 0; while (num >= 10) { num /= 10; count++; } count++; // 最后一位 cout << "该整数共有" << count << "位" << endl; ``` 此时,count变量的值即为该整数位数。 如何输出各位数字的个数? 我们可以用一个int类型的数组记录每个数字出现的次数。遍历该整数的每一位,将对应的数组元素加1。具体实现代码如下: ``` int num = 16644; int count = 0; int nums[10] = {0}; // 数字次数数组,下标0-9对应数字0-9 while (num >= 10) { int digit = num % 10; // 取个位数 nums[digit]++; // 对应数字次数加1 num /= 10; // 继续判断下一位 count++; // 总位数加1 } nums[num]++; // 最高位 count++; // 最后一位 cout << "该整数共有" << count << "位,各位数字的个数分别为:" << endl; for (int i = 0; i < 10; i++) { if (nums[i] != 0) { cout << i << "出现了" << nums[i] << "次" << endl; } } ``` 运行结果如下: ``` 该整数共有5位,各位数字的个数分别为: 1出现了2次 4出现了2次 6出现了1次 ``` 这个程序可以通过键盘输入获得整数,完整代码如下所示:
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值