鱼C论坛

 找回密码
 立即注册
查看: 919|回复: 1

[已解决]数组倒叙

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

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

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

x
使用函数编程,将n个整数逆序后输出。
输入
包括多组测试数据。

每组数据的第1个数为n,然后是n个整数。

输出
逆序后的n个整数。
最佳答案
2020-12-29 16:07:09
  1. #include <stdio.h>

  2. void reverse(int d[][50])
  3. {
  4.         int i , j , t                                   ;
  5.         for(i = 0 ; d[i][0] ; i ++) {
  6.                 for(j = 1 ; j < d[i][0] / 2 + 1 ; j ++) {
  7.                         t = d[i][d[i][0] - j + 1]       ;
  8.                         d[i][d[i][0] - j + 1] = d[i][j] ;
  9.                         d[i][j] = t                     ;
  10.                 }
  11.         }
  12. }

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

        编译、运行实况
  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 16:07:09 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>

  2. void reverse(int d[][50])
  3. {
  4.         int i , j , t                                   ;
  5.         for(i = 0 ; d[i][0] ; i ++) {
  6.                 for(j = 1 ; j < d[i][0] / 2 + 1 ; j ++) {
  7.                         t = d[i][d[i][0] - j + 1]       ;
  8.                         d[i][d[i][0] - j + 1] = d[i][j] ;
  9.                         d[i][j] = t                     ;
  10.                 }
  11.         }
  12. }

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

        编译、运行实况
  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 17:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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