如何用switch来判断你输入的数字是几位数
时间: 2023-04-03 19:04:03 浏览: 264
可以使用switch和strlen函数来判断输入的数字是几位数,代码如下:
```
#include <stdio.h>
#include <string.h>
int main() {
char num[100];
printf("请输入一个数字:");
scanf("%s", num);
switch(strlen(num)) {
case 1:
printf("这是一个一位数。\n");
break;
case 2:
printf("这是一个两位数。\n");
break;
case 3:
printf("这是一个三位数。\n");
break;
default:
printf("这是一个多位数。\n");
break;
}
return 0;
}
```
相关问题
如何只用switch来判断输入的数字有几位数
可以使用switch和整数除法运算符来判断输入的数字有几位数。具体实现如下:
int num; // 输入的数字
int count = 0; // 数字的位数
while (num != 0) {
num /= 10;
count++;
}
switch (count) {
case 1:
printf("输入的数字是一位数\n");
break;
case 2:
printf("输入的数字是两位数\n");
break;
case 3:
printf("输入的数字是三位数\n");
break;
default:
printf("输入的数字超过三位数\n");
break;
}
判断一个整型数据有几位v2.0\n从键盘输入一个整型数据(int型),用switch语句和循环语句编写程序判断该整数共有几位,并输出包含各个数字的个数。例如,从键盘输入整数16644,该整数共有5位,其
### 回答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次
```
这个程序可以通过键盘输入获得整数,完整代码如下所示:
相关推荐
![7z](https://img-home.csdnimg.cn/images/20210720083312.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)