c语言中怎么实现逆序存放字符串
时间: 2024-05-08 14:21:38 浏览: 107
在C语言中,可以通过数组和指针来实现字符串的逆序存放。以下是一种实现方式:
```c
#include <stdio.h>
#include <string.h>
void reverse(char *str) {
int len = strlen(str);
for (int i = 0; i < len / 2; i++) {
char temp = str[i];
str[i] = str[len - i - 1];
str[len - i - 1] = temp;
}
}
int main() {
char str[100];
printf("请输入一个字符串:");
scanf("%s", str);
reverse(str);
printf("逆序存放后的字符串为:%s\n", str);
return 0;
}
```
在上面的代码中,我们首先定义了一个 `reverse` 函数来实现字符串的逆序存放,它接受一个指向字符串的指针作为参数。在函数中,我们首先使用 `strlen` 函数获取字符串的长度,然后通过一个循环将字符串的前一半和后一半进行交换,最终实现字符串的逆序存放。在 `main` 函数中,我们通过 `scanf` 函数获取用户输入的字符串,并将其传递给 `reverse` 函数进行逆序存放。最后,我们将逆序存放后的字符串输出到屏幕上。
相关问题
c语言字符串逆序存放
C语言字符串逆序存放可以通过指针来实现。具体实现步骤如下:
1. 定义一个字符数组,并输入字符串。
2. 定义两个指针,一个指向字符串的首地址,一个指向字符串的末地址。
3. 通过循环交换首尾指针所指向的字符,直到首尾指针相遇。
4. 输出逆序后的字符串。
以下是C语言字符串逆序存放的代码实现:
```c
#include <stdio.h>
#include <string.h>
void reverse(char *str) {
char *p1, *p2;
p1 = str;
p2 = str + strlen(str) - 1;
while (p1 < p2) {
char temp = *p1;
*p1 = *p2;
*p2 = temp;
p1++;
p2--;
}
}
int main() {
char str[100];
printf("请输入一个字符串:");
scanf("%s", str);
reverse(str);
printf("逆序后的字符串为:%s\n", str);
return 0;
}
```
c语言字符串逆序存放指针
在C语言中,要实现字符串逆序存放,可以使用两个指针,一个指向字符串的开头(通常称为`start`),另一个指向字符串的结尾(通常称为`end`)。然后通过循环,每次交换这两个指针所指向的字符,直到它们相遇或交叉。
以下是一个简单的示例:
```c
#include <stdio.h>
#include <string.h>
void reverse(char* str) {
if (str == NULL || *str == '\0') {
return;
}
char start = *str; // 初始化指向第一个字符
char end = str[strlen(str) - 1]; // 初始化指向最后一个字符
while (start < end) { // 当start小于end时,继续交换
char temp = start;
start = end;
end = temp;
// 逐个字符地交换位置
start++;
end--;
}
// 将反转后的字符放回原数组
str[strlen(str) - 1] = start;
}
int main() {
char str[] = "Hello, World!";
printf("Original string: %s\n", str);
reverse(str);
printf("Reversed string: %s\n", str);
return 0;
}
```
在这个例子中,函数`reverse`会修改传入的字符串`str`,使其内容变为逆序。运行上述程序,原始字符串"Hello, World!"会被反转为 "!dlroW ,olleH"。
阅读全文