第1个回答 2008-11-12
楼上的程序存在两个缺点:1.循环次数过多 2.多次调用putchar,效率过低
lz可以参考下面的代码,效率比较高一点,而且相对来说代码比较漂亮一点。
#include <stdio.h>
#include <string.h>
#define SWAP(x, y) { \
x = x ^ y; \
y = x ^ y; \
x = x ^ y; \
}
void reserveArr(char *ch)
{
int i = 0;
int j = strlen(ch) - 1;
while (i < j) {
SWAP(ch[i], ch[j]);
i++;
j--;
}
}
int main()
{
char ch[1024] = {0};
gets(ch);
reserveArr(ch);
printf("ch = %s\n", ch);
}
第2个回答 2008-11-12
#include "stdio.h"
#include "string.h"
void main()
{ void inverse(char str[]);
char str[100];
printf("请输入一行字符串:\n");
scanf("%s",str);
inverse(str);
printf("反序字符串为:\n");
printf("%s\n",str);
}
void inverse(char str[])
{ char t;
int i,k;
k=strlen(str)-1;
for(i=0;i<(strlen(str)/2+1);i++,k--)
{
t=str[i];
str[i]=str[k];
str[k]=t;
}
}本回答被网友采纳
第4个回答 2008-11-12
#include<stdio.h>
#include<string.h>
main()
{
char a[100];
int n,i;
gets(a);
n=strlen(a)-1;
for(i=n;i>=0;i--)
putchar(a[i]);
getch();
}
win-tc试过了。。