鱼C论坛

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

[已解决]求助大佬C语言插入排序

[复制链接]
发表于 2022-1-2 09:13:18 | 显示全部楼层 |阅读模式

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

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

x
插入排序,已知一个数组int arr[10]中下标为0,2,3,5,7,9的数组元素分别为22,7,45,89,78,15,但下标为1,4,6,8的数组元素弄丢了,需要你从键盘输入,输入以后,请使用插入排序算法对该数组进行升序排序,输出前5个数(每个输出的数之间用一个空格隔开,最前面没有空格,最后有一个空格)。
输入示例:41 78 87 11
输出示例:7 11 15 22 41  网上找了攻略,说是像扑克牌一样,但是一直写不出代码
  1. #include <stdio.h>//这个是选择排序
  2. int main()
  3. {
  4.         int arr[10]={};
  5.         arr[0]=22;arr[2]=7;
  6.         arr[3]=45;
  7.         arr[5]=89;
  8.         arr[7]=78;
  9.         arr[9]=15;       
  10.         int i,j,k,l,m,a,b,c,d,temp;
  11.         scanf("%d %d %d %d",&arr[1],&arr[4],&arr[6],&arr[8]);
  12.         //arr[m]=l;
  13.        
  14.         for(i=0;i<9;i++)
  15.         {        int k=arr[i];
  16.                 for(j=i+1;j<10;j++)
  17.                 {
  18.                 if(k>arr[j])
  19.                 {               
  20.                 temp=arr[j];
  21.                 arr[j]=k;
  22.                 k=temp;
  23.                 }}

  24.         arr[i]=k;}
  25.                 for(i=0;i<5;i++)
  26.         {
  27.                 printf("%d ",arr[i]);
  28.         }
  29. }
复制代码

最佳答案
2022-1-2 11:15:51
  1. #include <stdio.h>

  2. int main(){
  3.     int arr[] = {22, 7, 45, 89, 78, 15};
  4.     int res[] = {0, 1, 0, 0, 1, 0, 1, 0, 1, 0};
  5.     int num;
  6.    
  7.     for(int i = 0, j = 0; i < 10; i++){
  8.         if(res[i]) scanf("%d", &res[i]);
  9.         else res[i] = arr[j++];
  10.     }
  11.    
  12.     printf("初始数组:\n");
  13.     for(int i = 0; i < 10; i++) printf("%d ", res[i]);
  14.    
  15.     printf("\n\n插入排序:");
  16.     for(int i = 0; i < 10; i++)
  17.     for(int j = 0; j < i; j++)
  18.     if(res[j] > res[i]){
  19.         num = res[i];
  20.         for(int k = i; k > j; k--) res[k] = res[k-1];
  21.         res[j] = num;
  22.         printf("\n");
  23.         for(int i = 0; i < 10; i++) printf("%d ", res[i]);
  24.     }
  25.    
  26.     printf("\n\n输出前5个数:\n");
  27.     for(int i = 0; i < 5; i++) printf("%d ", res[i]);
  28.    
  29.     return 0;
  30. }
复制代码
  1. 41 78 87 11
  2. 初始数组:
  3. 22 41 7 45 78 89 87 78 11 15

  4. 插入排序:
  5. 7 22 41 45 78 89 87 78 11 15
  6. 7 22 41 45 78 87 89 78 11 15
  7. 7 22 41 45 78 78 87 89 11 15
  8. 7 11 22 41 45 78 78 87 89 15
  9. 7 11 15 22 41 45 78 78 87 89

  10. 输出前5个数:
  11. 7 11 15 22 41
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-1-2 11:15:51 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>

  2. int main(){
  3.     int arr[] = {22, 7, 45, 89, 78, 15};
  4.     int res[] = {0, 1, 0, 0, 1, 0, 1, 0, 1, 0};
  5.     int num;
  6.    
  7.     for(int i = 0, j = 0; i < 10; i++){
  8.         if(res[i]) scanf("%d", &res[i]);
  9.         else res[i] = arr[j++];
  10.     }
  11.    
  12.     printf("初始数组:\n");
  13.     for(int i = 0; i < 10; i++) printf("%d ", res[i]);
  14.    
  15.     printf("\n\n插入排序:");
  16.     for(int i = 0; i < 10; i++)
  17.     for(int j = 0; j < i; j++)
  18.     if(res[j] > res[i]){
  19.         num = res[i];
  20.         for(int k = i; k > j; k--) res[k] = res[k-1];
  21.         res[j] = num;
  22.         printf("\n");
  23.         for(int i = 0; i < 10; i++) printf("%d ", res[i]);
  24.     }
  25.    
  26.     printf("\n\n输出前5个数:\n");
  27.     for(int i = 0; i < 5; i++) printf("%d ", res[i]);
  28.    
  29.     return 0;
  30. }
复制代码
  1. 41 78 87 11
  2. 初始数组:
  3. 22 41 7 45 78 89 87 78 11 15

  4. 插入排序:
  5. 7 22 41 45 78 89 87 78 11 15
  6. 7 22 41 45 78 87 89 78 11 15
  7. 7 22 41 45 78 78 87 89 11 15
  8. 7 11 22 41 45 78 78 87 89 15
  9. 7 11 15 22 41 45 78 78 87 89

  10. 输出前5个数:
  11. 7 11 15 22 41
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-25 06:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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