编写一个字符串逆序存放的函数reverse(),并由主函数调用实现对字符串的逆序操作。

2024-11-07 19:31:29
推荐回答(3个)
回答1:

利用指针实现,动态判断大小,可以参考

#include
#include
void reverse(char a[]){
int i=strlen(a);
char *s=a,*e=&a[i-1],t;
while(e>s){
t=*s;*s=*e;*e=t;s++;e--;
}
}
int main(){
char a[1024];
int i=0;
while((a[i]=getchar())!='\n') i++;
a[i]='\0';
reverse(a);
puts(a);
return 0;
}

回答2:

反序字符串,只需要将首尾字符依次调换即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

#include
#include

// 反序字符串x并返回
char* reverse(char *x)
{
int len = strlen(x);
int i, n = len / 2;
char tem;
for (i = 0; i <= n; i++)
{
tem = x[i];
x[i] = x[len - 1 - i];
x[len - 1 - i] = tem;
}
return x;
}

int main()
{
char str[100];
printf("input a string :");
gets(str);
puts(reverse(str));
return 0;

回答3:

#include

#include

#define N 50

int reverse (char a[])

{

int len, i;

len= strlen(a);

for(i=len-1;i>=0;i--)

{

printf("%c",a[i]);

}

}

int main()

{

char a[N],i;

gets(a);

reverse(a,N);

return 0;

}