c++代码 编写一个递归函数,将一个正整数的每一位取出来并按从高位到低位的顺序依次输出,数字之间加上短横线。 例如:正整数为123,则输出1-2-3。 提示:考虑用递归函数实现该任务。
时间: 2024-01-22 14:19:49 浏览: 156
以下是C++代码实现:
```c++
#include<iostream>
using namespace std;
void printDigits(int n) {
if (n < 10) {
cout << n << "-";
} else {
printDigits(n / 10);
cout << n % 10 << "-";
}
}
int main() {
int n = 123;
printDigits(n);
return 0;
}
```
运行结果为:`1-2-3-`
该递归函数的基本思路是:如果给定的数是个位数,直接输出并返回;否则,将其除以10得到高位数字,递归输出高位数字,然后输出当前位的数字。
相关问题
c++编写一个递归函数,将一个正整数的每一位取出来并按从高位到低位的顺序依次输出,数字之间加上短横线。
以下是C++递归函数的实现:
```cpp
#include <iostream>
using namespace std;
void printDigits(int n) {
if (n < 10) { // 如果只剩一位数字
cout << n; // 直接输出该数字
} else { // 否则递归输出高位数字
printDigits(n / 10);
cout << "-" << n % 10; // 输出当前位数字并加上短横线
}
}
int main() {
int n;
cout << "请输入一个正整数:";
cin >> n;
cout << "该数字的每一位为:";
printDigits(n);
cout << endl;
return 0;
}
```
该程序会从输入读取一个正整数,然后调用`printDigits`函数递归输出该数字的每一位。在递归过程中,每次先递归输出高位数字,然后输出当前位数字并加上短横线。最终输出的数字是从高位到低位的顺序。例如,输入12345,输出为1-2-3-4-5。
C++编写一个递归函数,将一个正整数的每一位取出来并按从高位到低位的顺序依次输出,数字之间加上短横线。
以下是实现该功能的 C++ 递归函数代码:
```cpp
void printDigits(int num) {
if (num < 10) {
cout << num << "-";
} else {
printDigits(num / 10);
cout << num % 10 << "-";
}
}
```
这个函数首先判断传入的数字是否小于 10,如果是,则直接输出该数字并加上短横线,递归结束;否则,先递归调用自身处理 num 除以 10 的结果,再输出 num 对 10 取余的结果并加上短横线。这样就能够从高位到低位依次输出每一位数字了。
阅读全文