C++语言基础:输出一个整数的个位十位百位上的数字
原创
©著作权归作者所有:来自51CTO博客作者51CTO_zhangsz的原创作品,请联系作者获取转载授权,否则将追究法律责任
功能描述
- 输入一个数,如一个三位数,输出其个位、十位、百位上的数字
- 如 123 这个数
- 求个位: 对 10 取模(123 % 10 = 3 即可),
- 求十位, 先把 123 除以 10,得到 12, 再对 10 取模(123 / 10 % 10 = 2)
- 求百位,先把 123 除以 100,得到 1, 再对10取模(123 / 10 / 10 % 10 = 1),所以:个位 :3, 十位 : 2, 百位 : 1
- 如果求千位, 就是
数 / 1000 % 10
,所以灵活运用【取模】,就可以得到每位的数字
代码
- visual studio 2022 ,新建一个【控制台】 C++ 程序
/* 训练1-3:输入一个数,输出其个位、十位、百位上的数字 */
#include <iostream>
using namespace std;
int main()
{
int n;
int ge, shi, bai;
while (1)
{
cout << "输入一个数值:";
cin >> n;
if (n < 0)
break;
ge = n % 10;
shi = (n / 10) % 10;
bai = (n / 100) % 10;
cout << "个位:" << ge << endl;
cout << "十位:" << shi << endl;
cout << "百位:" << bai << endl;
}
return 0;
}
运算效果
- 可以正确的取出 个、十、百位上数字,根据这个规律,可以取其他数位上的数字
输出整数的各个位上的数字
/* 训练1-3-2:输入一个数,输出十进制各个数位上的数字 */
#include <iostream>
#include <math.h>
using namespace std;
#define MAX_WEI_LEN 20
int main()
{
long long n = 0;
int i = 0;
int j = 0;
char shuwei[MAX_WEI_LEN] = { 0 };
while (1)
{
cout << "输入一个数值:";
cin >> n;
if (n < 0)
break;
for (i = 0; i < MAX_WEI_LEN; i++)
{
shuwei[i] = (n / (long long)pow(10, i)) % 10;
shuwei[i] += 0x30; /* 0x01 -> `1` */
}
for (i = 0; i < MAX_WEI_LEN; i++)
{
cout << shuwei[i] << " ";
}
cout << endl;
}
return 0;
}
效果
- 这里因为使用了 求幂 的函数:pow,造成数字不能过大,可以尝试使用 自定义的 【求幂】函数,这样可以分解一个大的整数的各个数位上的数字
- 各个数位上的数字,如 0x1,不能直接显示,可以 加上 0x30,因为 0x30 是 ASCII 码字符:
0
笔记
- 求整数各个数位上的值的方法,注意 如果使用标准的求幂函数,则限制了数值的大小,也就是十进制整数的位数