原题链接:[编程入门]数组插入处理
解题思路:
本答案是可以随意输入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; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复