使用c语言编写程序,输入一串字符(长度不超过80个字符),要求不开辟其它数组而将该字符串逆序存放,并输出逆序后的字符串内容。(要求用字符指针来实现
时间: 2023-06-20 19:10:40 浏览: 180
可以使用字符指针和指针运算来实现字符串的逆序存放,具体代码如下:
```c
#include <stdio.h>
#include <string.h>
int main()
{
char str[81], *p1, *p2;
printf("请输入一个不超过80个字符的字符串:");
scanf("%s", str);
p1 = str; // p1指向字符串首地址
p2 = str + strlen(str) - 1; // p2指向字符串末尾地址
while (p1 < p2) // 交换字符
{
char temp = *p1;
*p1 = *p2;
*p2 = temp;
p1++;
p2--;
}
printf("逆序后的字符串为:%s\n", str);
return 0;
}
```
在上面的代码中,首先定义了一个字符数组 `str` 和两个字符指针 `p1` 和 `p2`。然后输入字符串并将 `p1` 指向字符串首地址,`p2` 指向字符串末尾地址。接着使用 `while` 循环来不断交换 `p1` 和 `p2` 指向的字符,直到 `p1` 大于等于 `p2`。最后输出逆序后的字符串即可。
需要注意的是,输入字符串时使用 `%s` 格式化字符串,这样可以避免字符串中包含空格等空白字符导致输入错误。
相关问题
c语言字符指针输入一串字符(长度不超过80个字符),要求不开辟其它数组而将该字符串逆序存放,并输出逆序后的字符串内容。(要求用字符数组和字符指针两种方式来实现)
使用字符数组实现:
```c
#include <stdio.h>
#include <string.h>
int main() {
char str[81];
printf("请输入字符串(长度不超过80个字符):");
scanf("%s", 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;
}
printf("逆序后的字符串为:%s\n", str);
return 0;
}
```
使用字符指针实现:
```c
#include <stdio.h>
#include <string.h>
int main() {
char str[81];
printf("请输入字符串(长度不超过80个字符):");
scanf("%s", str);
char *p = str;
int len = strlen(str);
for (int i = 0; i < len / 2; i++) {
char temp = *(p + i);
*(p + i) = *(p + len - i - 1);
*(p + len - i - 1) = temp;
}
printf("逆序后的字符串为:%s\n", str);
return 0;
}
```
c语言编写一个函数 Inverse0,实现将字符数组中的字符串逆序存放的功能。用数组a存放逆序存放前的数组元素,用数组b存放逆序存放后的数组元素。
好的,以下是C语言实现的代码:
```c
void Inverse0(char* str) {
char a[1000], b[1000];
int len = strlen(str);
for (int i = 0; i < len; i++) {
a[i] = str[i];
}
for (int i = 0; i < len; i++) {
b[i] = a[len - i - 1];
}
for (int i = 0; i < len; i++) {
str[i] = b[i];
}
}
```
以上代码中,我们先将原始字符串按照顺序存储到数组a中,然后再将数组a中的元素按照相反的顺序存储到数组b中,最后再将数组b中的元素按照顺序存储回原始字符串中,即可实现字符串逆序存放的功能。
请注意,由于我们使用了数组a和数组b,因此需要定义一个足够大的数组来存储字符串,以上代码中我们定义了大小为1000的数组。如果您的字符串比较长,可能需要调整数组的大小。
阅读全文