在数组本地逆序一个字符串
时间: 2023-12-26 15:24:34 浏览: 25
可以通过双指针来实现。首先,将字符串转为字符数组,然后用两个指针分别指向字符数组的首尾。然后交换指针所指向的字符,直到两个指针相遇为止。
下面是 Java 代码示例:
```java
public static void reverseString(char[] s) {
int left = 0, right = s.length - 1;
while (left < right) {
char temp = s[left];
s[left++] = s[right];
s[right--] = temp;
}
}
```
调用 `reverseString` 方法时,传入需要逆序的字符串即可。例如:`reverseString("hello".toCharArray())` 会将字符数组 `['h', 'e', 'l', 'l', 'o']` 逆序为 `['o', 'l', 'l', 'e', 'h']`。
相关问题
用C语言在数组本地逆序一个字符串
可以使用双指针来实现。具体步骤如下:
1. 定义两个指针,一个指向字符串的开头,另一个指向结尾。
2. 不断交换两个指针所指的字符,并将指针向中间移动,直到两个指针相遇。
3. 交换完成后,整个字符串就被本地逆序了。
以下是代码实现:
```c
#include <stdio.h>
#include <string.h>
void reverse_string(char* str) {
int len = strlen(str);
char *p1 = str, *p2 = str + len - 1;
while (p1 < p2) {
char tmp = *p1;
*p1 = *p2;
*p2 = tmp;
p1++;
p2--;
}
}
int main() {
char str[] = "hello world";
reverse_string(str);
printf("%s\n", str); // 输出: "dlrow olleh"
return 0;
}
```
注意,本地逆序只是将字符串在数组中的顺序颠倒过来,并不改变字符串在内存中的地址。因此,该函数不需要返回值。
将一个字符串逆序存放在数组中并输出逆序后的字符串内容。
下是C++代码实现:
```cpp
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char str[100];
cout << "请输入一个字符串:" << endl;
cin.getline(str, 100); // 使用getline()函数读取含有空格的字符串
int len = strlen(str);
char reverse_str[len];
for (int i = 0; i < len; i++) {
reverse_str[i] = str[len - i - 1]; // 逆序存放
}
cout << "逆序后的字符串为:" << endl;
cout << reverse_str << endl;
return 0;
}
```
当用户输入一个字符串后,程序会先通过`strlen()`函数获取字符串的长度,然后创建一个与原字符串等长的字符数组`reverse_str`,并在`for`循环中将原字符串逆序存放到`reverse_str`中。最后输出`reverse_str`即可。