第2个回答 2013-12-19
#include <stdio.h>
int length(char *s)
{
int num = 0;
if(s == NULL)
return num;
while(s[num] != '\0')
{
num++;
}
return num;
}
void convert(char *s)
{
int size = length(s);
char ch;
for (int i = 0; i < size/2; ++i)
{
ch = s[i];
s[i] = s[size - i - 1];
s[size - i - 1] = ch;
}
}
int main()
{
char str[20];
scanf("%s",str);
convert(str);
printf("%s\n", str);
return 0;
}
//没验证 ,我这里没工具,在文本上编的,有不懂的在问
第3个回答 2013-12-19
// 兵无常势,水无常形,只用递归,不用循环
#include <stdio.h>
#define SWAP(a,b) a^=b^=a^=b
void convert(char *s, int n)
{
if (n>1)
{
SWAP(*s, *(s+n-1));
convert(s+1, n-2);
}
}
int length(char *s)
{
return *s ? 1 + length(s+1) : 0;
}
void main()
{
char str[BUFSIZ];
printf("Input String: ");
gets_s(str, BUFSIZ);
convert(str, length(str));
printf("The convert string is <%s>\n", str);
getchar();
}