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

2024年11月29日 18:27
有4个网友回答
网友(1):

#include
#include

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):

#include
void y(char *s)
{if(*s!='\0') y(s+1);
printf("%c ",*s);
}
void main()
{
char s[100]="12345";
y(s);
}
函数y就是按照递归实现一个字符串的逆序输出

网友(3):

#include
#include
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):

#include "stdio.h"
#include "string.h"
#include
using namespace std;

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