解题思路:
本答案是可以随意输入9个没有排序的元素,用选择排序法排序;

然后用二分查找插入排序决定第十个元素的位置;

希望对大家有用!


注意事项:
本题的创新点在于用宏定义来决定数组的大小,如#define getlen(array,len){len=sizeof(array)/sizeof(array[0]);}  这样设置智能,但在这里鸡肋


参考代码:

#include <stdio.h>
#define getlen(array,len){len=sizeof(array)/sizeof(array[0]);}
//宏定义数组长度

 int main()
{
    //selection sort
   int a[9];
   int len,newone;
   getlen(a,len);
   for(int i=0;i<len;i++){
    scanf("%d",&a[i]);
   }
   int min,swap,temp;
   for(int i=0;i<len;i++){
        min=a[i];
        temp=i;
         for(int j=i+1;j<len;j++){
            if(min>=a[j]){
                min=a[j];
                temp=j;
            }
         }
         swap=a[i];
         a[i]=a[temp];
         a[temp]=swap;
      
   }
   scanf("%d",&newone);//新输入待排序元素
   int low=0, high=len-1; //二分查找插入排序
   int mid;
   while(low<=high){
       mid=(high+low)/2;
       if(newone<a[mid]){
               high=mid-1;
       }else
       low=mid+1;
   }
   if(newone>a[mid]){//非常重要,决定新插入元素在mid的前面还是后面
        mid++;
   }
   int b[10];
   for(int i=0;i<len;i++){//新数组插入新元素
        if(i<mid){
            b[i]=a[i];
        }else{
            b[i+1]=a[i];
        }
   }
    b[mid]=newone;
    
    int b_len;
    getlen(b,b_len);
   for(int i=0;i<b_len;i++){
     printf("%d\n",b[i]);
   }
//getch();
   return 0;
}


点赞(1)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论