按照递归实现一个字符串的逆序输出。 如输入一个字符串12345,输出为54321 c语言程序,谢啦

如题所述

第1个回答  2011-04-07
#include<stdio.h>
#include<string.h>

void reverse(char *s,int length){
if(length==1){
printf("%c",s[0]);

}else{
reverse(&s[1],length-1);
reverse(&s[0],1);
}
}
void main(){
char input[]="1720470234";
puts(input);
int l=strlen(input);
reverse(input,l);
printf("\n");
}

就这个本回答被提问者采纳
第2个回答  2011-04-07
#include<stdio.h>
void y(char *s)
{if(*s!='\0') y(s+1);
printf("%c ",*s);
}
void main()
{
char s[100]="12345";
y(s);
}
函数y就是按照递归实现一个字符串的逆序输出

参考资料:自己写的,简明易懂

第3个回答  2011-04-07
#include <stdio.h>
#include <string.h>
void reverse(char str[])
{
static int len = strlen(str) - 1;
if (len != -1)
{
printf("%c", str[len]);
--len;
reverse(str);
}
}
int main()
{
char str[] = "12345";
reverse(str);
return 0;
}
第4个回答  2011-04-07
#include "stdio.h"
#include "string.h"
#include <iostream>
using namespace std;

void reverseNum(char* str){
if(0== str || 0 == strlen(str))
{
cout<<endl;
return;
}
int cnt = strlen(str);
char c = str[cnt-1];
str[cnt-1] = 0;
cout<<c;
reverseNum(str);
}
int main(int argc, char* argv[])
{
while(1){
char str[16];
scanf("%16s",str);
reverseNum(str);
}
return 0;
}