鱼C论坛

 找回密码
 立即注册
查看: 987|回复: 2

[已解决]递归函数 倒叙输出

[复制链接]
发表于 2020-12-29 15:14:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述
输入多个整数,以0结束,将这些整数逆序后输出。

要求:使用递归函数将数组倒序,在main中调用递归函数。

输入
多个整数,最后为0。

输出
逆序后的这些整数。
最佳答案
2020-12-29 16:20:56
本帖最后由 jackz007 于 2020-12-29 16:35 编辑
  1. #include <stdio.h>

  2. void reverse(int d[] , int a , int b)
  3. {
  4.         int t                              ;
  5.         if(a < b) {
  6.                 t = d[a]                   ;
  7.                 d[a] = d[b]                ;
  8.                 d[b] = t                   ;
  9.                 reverse(d , a + 1 , b - 1) ;
  10.         }
  11. }

  12. int main(void)
  13. {
  14.         int d[50][50] , i , j , n                                                       ;
  15.         for(i = 0 ;; i ++) {
  16.                 fflush(stdin)                                                           ;
  17.                 scanf("%d" , & d[i][0])                                                 ;
  18.                 if(d[i][0]) for(j = 1 ; j < d[i][0] + 1 ; j ++) scanf("%d" , & d[i][j]) ;
  19.                 else break                                                              ;
  20.         }
  21.         for(i = 0 ; d[i][0]; i ++) {
  22.                 printf("%d" , d[i][1])                                      ;
  23.                 for(j = 2 ; j < d[i][0] + 1 ; j ++) printf(" %d" , d[i][j]) ;
  24.                 printf("\n")                                                ;
  25.         }
  26.         for(i = 0 ; d[i][0] ; i ++) reverse(& d[i][1] , 0 , d[i][0] - 1)    ;
  27.         printf("after reverse.\n")                                          ;
  28.         for(i = 0 ; d[i][0]; i ++) {
  29.                 printf("%d" , d[i][1])                                      ;
  30.                 for(j = 2 ; j < d[i][0] + 1 ; j ++) printf(" %d" , d[i][j]) ;
  31.                 printf("\n")                                                ;
  32.         }        
  33. }
复制代码

        编译、运行实况:
  1. D:\0002.Exercise\C>g++ -o x x.c

  2. D:\0002.Exercise\C>x
  3. 5
  4. 1 2 3 4 5
  5. 6
  6. 11 12 13 14 15 16
  7. 7
  8. 21 22 23 24 25 26 27
  9. 0
  10. 1 2 3 4 5
  11. 11 12 13 14 15 16
  12. 21 22 23 24 25 26 27
  13. after reverse.
  14. 5 4 3 2 1
  15. 16 15 14 13 12 11
  16. 27 26 25 24 23 22 21

  17. D:\0002.Exercise\C>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-12-29 15:42:13 | 显示全部楼层
666
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-12-29 16:20:56 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2020-12-29 16:35 编辑
  1. #include <stdio.h>

  2. void reverse(int d[] , int a , int b)
  3. {
  4.         int t                              ;
  5.         if(a < b) {
  6.                 t = d[a]                   ;
  7.                 d[a] = d[b]                ;
  8.                 d[b] = t                   ;
  9.                 reverse(d , a + 1 , b - 1) ;
  10.         }
  11. }

  12. int main(void)
  13. {
  14.         int d[50][50] , i , j , n                                                       ;
  15.         for(i = 0 ;; i ++) {
  16.                 fflush(stdin)                                                           ;
  17.                 scanf("%d" , & d[i][0])                                                 ;
  18.                 if(d[i][0]) for(j = 1 ; j < d[i][0] + 1 ; j ++) scanf("%d" , & d[i][j]) ;
  19.                 else break                                                              ;
  20.         }
  21.         for(i = 0 ; d[i][0]; i ++) {
  22.                 printf("%d" , d[i][1])                                      ;
  23.                 for(j = 2 ; j < d[i][0] + 1 ; j ++) printf(" %d" , d[i][j]) ;
  24.                 printf("\n")                                                ;
  25.         }
  26.         for(i = 0 ; d[i][0] ; i ++) reverse(& d[i][1] , 0 , d[i][0] - 1)    ;
  27.         printf("after reverse.\n")                                          ;
  28.         for(i = 0 ; d[i][0]; i ++) {
  29.                 printf("%d" , d[i][1])                                      ;
  30.                 for(j = 2 ; j < d[i][0] + 1 ; j ++) printf(" %d" , d[i][j]) ;
  31.                 printf("\n")                                                ;
  32.         }        
  33. }
复制代码

        编译、运行实况:
  1. D:\0002.Exercise\C>g++ -o x x.c

  2. D:\0002.Exercise\C>x
  3. 5
  4. 1 2 3 4 5
  5. 6
  6. 11 12 13 14 15 16
  7. 7
  8. 21 22 23 24 25 26 27
  9. 0
  10. 1 2 3 4 5
  11. 11 12 13 14 15 16
  12. 21 22 23 24 25 26 27
  13. after reverse.
  14. 5 4 3 2 1
  15. 16 15 14 13 12 11
  16. 27 26 25 24 23 22 21

  17. D:\0002.Exercise\C>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-3 16:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表