C++用递归逆置字符串
时间: 2023-10-05 14:09:51 浏览: 84
可以递归函数来逆置一个字符串,具体实现如下:
```c++
#include <iostream>
#include <string>
using namespace std;
void reverse(string& s, int left, int right) {
if (left >= right) {
return;
}
// 交换左右两边的字符
swap(s[left], s[right]);
// 递归处理中间的字符
reverse(s, left + 1, right - 1);
}
int main() {
string s = "Hello, world!";
reverse(s, 0, s.size() - 1);
cout << s << endl;
return 0;
}
```
在递归函数`reverse()`中,我们比较左右两端的下标,如果左下标大于等于右下标,说明已经逆置完成,直接返回。否则,我们将左右两个字符交换,并递归处理中间的字符。最终,整个字符串就被逆置了。
相关问题
用c++语言实现假设一个字符串s采用string对象表示,设置一个递归算法逆置所有字符
可以通过递归算法实现字符串的逆置,具体实现如下:
```c++
#include <iostream>
#include <string>
using namespace std;
void reverseString(string& s, int left, int right) {
// 递归终止条件
if (left >= right) {
return;
}
// 交换左右两个字符
char temp = s[left];
s[left++] = s[right];
s[right--] = temp;
// 继续递归
reverseString(s, left, right);
}
int main() {
string s = "hello world";
reverseString(s, 0, s.size() - 1);
cout << s << endl;
return 0;
}
```
以上代码中,`reverseString` 函数接受三个参数,分别表示字符串、左边界和右边界。在每次递归时,我们交换左右两个字符的位置,并将左边界加一,右边界减一,然后继续递归下去,直到左右边界相遇为止。最终,字符串中所有字符的顺序都被逆置了。
使用c++实现 十进制于三十二进制的相互转化
### 回答1:
好的,下面是使用 C 语言实现十进制与三十二进制相互转化的代码示例。
首先是十进制转三十二进制的函数:
```
void decToHex(long long n)
{
char hexaDeciNum[100];
// 递归转换为三十二进制数
int i = 0;
while(n!=0)
{
int temp = 0;
// 临时变量记录余数
temp = n % 32;
// 将三十二进制转换为ASCII码
if(temp < 10)
{
hexaDeciNum[i] = temp + 48;
i++;
}
else
{
hexaDeciNum[i] = temp + 55;
i++;
}
n = n/32;
}
// 反转字符串
reverse(hexaDeciNum, hexaDeciNum + strlen(hexaDeciNum));
printf("%s\n", hexaDeciNum);
}
```
接下来是三十二进制转十进制的函数:
```
long long hexToDec(char* hexVal)
{
long long deciVal = 0;
// 从右向左遍历字符串
for (int i=strlen(hexVal)-1; i>=0; i--)
{
// 将字符转换为数字
if (hexVal[i]>='0' && hexVal[i]<='9')
{
deciVal += (hexVal[i] - 48)*pow(32, strlen(hexVal)-1-i);
}
else if (hexVal[i]>='A' && hexVal[i]<='Z')
{
deciVal += (hexVal[i] - 55)*pow(32, strlen(hexVal)-1-i);
}
}
return deciVal;
}
```
使用这些函数时,你可以这样调用:
```
long long n;
char hexaDeciNum[100];
// 输入十进制数
printf("Enter a decimal number: ");
scanf("%lld", &n);
// 转换为三十二进制数
decToHex(n);
//
### 回答2:
使用C语言实现十进制到三十二进制的相互转化的思路如下:
1. 十进制转三十二进制:首先,我们需要对十进制数进行求余运算,从而得到每一位的余数,这个余数即为三十二进制数的一位;然后,将余数存储到数组中;接着,将原十进制数除以32再次进行整除和求余的循环运算,直到原十进制数为0,结束循环;最后,逆置数组中的元素,即可得到三十二进制数。
```c
#include <stdio.h>
void decimalToBase32(int decimal, char base32[]) {
int remainder, i = 0;
while (decimal != 0) {
remainder = decimal % 32;
base32[i] = remainder + '0';
decimal /= 32;
i++;
}
base32[i] = '\0';
// Reverse the digits
int start = 0, end = i - 1;
while (start < end) {
char temp = base32[start];
base32[start] = base32[end];
base32[end] = temp;
start++;
end--;
}
}
void base32ToDecimal(char base32[], int* decimal) {
int i = 0;
while (base32[i] != '\0') {
*decimal = *decimal * 32 + (base32[i] - '0');
i++;
}
}
int main() {
int decimal;
char base32[50];
// 十进制转三十二进制
decimal = 1234;
decimalToBase32(decimal, base32);
printf("The base-32 representation of %d is %s\n", decimal, base32);
// 三十二进制转十进制
char base32Number[] = "2HI";
int convertedDecimal = 0;
base32ToDecimal(base32Number, &convertedDecimal);
printf("The decimal representation of %s is %d\n", base32Number, convertedDecimal);
return 0;
}
```
以上代码实现了十进制到三十二进制的转化以及反向转化。输入的十进制数为1234,输出的三十二进制数为4532;输入的三十二进制数为"2HI",输出的十进制数为14692。
### 回答3:
使用C语言可以实现十进制与三十二进制的相互转化。具体实现步骤如下:
1. 十进制转三十二进制:
- 创建一个数组用于存储三十二进制的每一位数字。
- 使用循环将十进制数除以32,将余数存储在数组中,然后更新十进制数为商。
- 当十进制数为0时,结束循环。
- 反向遍历数组,将每一位数字转化为对应的三十二进制字符。
- 输出转化后的三十二进制数。
2. 三十二进制转十进制:
- 创建一个变量用于存储最终的十进制数。
- 使用循环遍历三十二进制数的每一位。
- 将每一位字符转化为对应的数字。
- 将转化后的数字乘以32的幂次方,并累加到最终的十进制数中。
- 输出转化后的十进制数。
下面是一个简单的示例代码,实现了十进制与三十二进制的相互转化:
```c
#include <stdio.h>
#include <string.h>
void decimalToThirtyTwo(int decimal) {
int thirtyTwo[10] = {0};
int i = 0;
while (decimal > 0) {
thirtyTwo[i++] = decimal % 32;
decimal /= 32;
}
for (i = 9; i >= 0; i--) {
printf("%c", thirtyTwo[i] + '0');
}
printf("\n");
}
int thirtyTwoToDecimal(char thirtyTwo[]) {
int decimal = 0;
int len = strlen(thirtyTwo);
int i;
for (i = 0; i < len; i++) {
decimal += (thirtyTwo[i] - '0') * pow(32, len - i - 1);
}
return decimal;
}
int main() {
int decimal = 9876;
char thirtyTwo[] = "10X";
printf("十进制转三十二进制:\n");
decimalToThirtyTwo(decimal);
printf("三十二进制转十进制:\n");
printf("%d\n", thirtyTwoToDecimal(thirtyTwo));
return 0;
}
```
通过上述代码,可以实现十进制与三十二进制的相互转化。其中,`decimalToThirtyTwo`函数将十进制数转化为三十二进制,并输出结果;`thirtyTwoToDecimal`函数接收一个三十二进制字符数组,将其转化为十进制数并返回。在示例中,十进制数为9876,将其转化为三十二进制后输出为"001020",然后将三十二进制数"10X"转化为十进制数,并输出结果为19792。
阅读全文