写C++实现一个函数,将一个整数的各位数字的反序打印
时间: 2023-05-11 18:02:00 浏览: 124
这是一个简单的程序,可以使用循环和取模运算来实现:
```c
#include <stdio.h>
void reverse_digits(int num) {
while (num > 0) {
int digit = num % 10;
printf("%d", digit);
num /= 10;
}
}
int main() {
int num = 12345;
reverse_digits(num);
return 0;
}
```
这个程序将输出:54321
相关问题
整数与其反序数的和 题目描述 给定一个整数,要求输出该整数与其反序数的和。 输入:一个整数,位数小于200位。 输出:一个整数,即要求的和。 样例输入: 123 样例输出 444 样例输入: 555 样例输出 1110 用c++实现 不用函数
以下是使用C++实现的代码,不使用函数:
```cpp
#include <iostream>
#include <string>
#include <algorithm>
int main() {
std::string num_str;
std::cin >> num_str; // 输入整数
std::string reversed_str = num_str;
std::reverse(reversed_str.begin(), reversed_str.end()); // 反转字符串
int num = std::stoi(num_str); // 将原始字符串转换为整数
int reversed_num = std::stoi(reversed_str); // 将反转后的字符串转换为整数
int sum = num + reversed_num; // 计算和
std::cout << sum << std::endl; // 输出结果
return 0;
}
```
在这个实现中,我们首先使用`std::string`类型接收输入的整数,然后将其复制到另一个字符串`reversed_str`中。通过使用`std::reverse()`函数反转`reversed_str`字符串,我们得到了反序的字符串。
然后,使用`std::stoi()`将原始字符串和反序字符串分别转换为整数。最后,将这两个整数相加并输出结果。
请注意,在这个实现中,我们没有使用函数来封装代码,而是直接在`main()`函数中进行操作。
c++实现调用rand( )函数在[10,500]范围内随机产生若干个整数, 判断并输出其中的可逆素数(一个素数,将其各位数字的顺 序倒过来构成的反序数也是素数)。例如:347是素数,其 反序数743也是素数,所以347是可逆素数。
以下是实现代码:
```c
#include <stdio.h>
#include <stdlib.h>
int isPrime(int n) {
if (n <= 1) {
return 0;
}
for (int i = 2; i * i <= n; i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
int reverseNum(int n) {
int res = 0;
while (n) {
res = res * 10 + n % 10;
n /= 10;
}
return res;
}
int main() {
int n, num, reversed;
printf("请输入随机数的个数:");
scanf("%d", &n);
for (int i = 0; i < n; i++) {
num = rand() % 491 + 10; // 产生10~500之间的随机数
reversed = reverseNum(num);
if (isPrime(num) && isPrime(reversed)) {
printf("%d是可逆素数\n", num);
}
}
return 0;
}
```
思路:先编写判断素数的函数`isPrime()`和反转数字的函数`reverseNum()`,然后在主函数中产生若干个随机数,判断每个数是否为可逆素数,是则输出。其中,产生随机数的方式为利用`rand()`函数生成0~490之间的随机数再加上10,即可得到10~500之间的随机数。
阅读全文