c语言编程题,急急急!!!!

编写函数length(char *s),其功能为计算字符串s的串长并返回,休息不能使用库函数strlen。编写函数convert(char *s),其功能是将字符串s倒置,要求调用length函数求串长。编写主函数,输入字符串str,调用convert函数将其倒置输出

/*

数入字符串:123asd

反转后:dsa321

Press any key to continue

*/

#include <stdio.h>

#define MAXlen 100

int length(char *s) {
int len = 0;
while(s[len]) ++len;
return len;
}

void convert(char *s) {
int i,len = length(s);
char ch;
for(i = 0; i < len/2; ++i) {
ch = s[i];
s[i] = s[len - 1 - i];
s[len - 1 - i] = ch;
}
}

int main() {
char str[MAXlen];
printf("数入字符串:");
gets(str);
convert(str);
printf("反转后:%s\n",str);
return 0;
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-12-19
挺简单啊
int length(char *s)
{
int i=0;
while(s[i++]);
return i;
}

反序也不难,就是循环一半
void convert(char *s)
{
int i;
int k=length(s);
char t;
for(i=0;i<k/2;i++)
{
t=s[i];
s[i]=s[k-i-1];
s[k-i-1]=t;
}
}
第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();
}