实现对二维数组 6X 5按列排序,即竖向从大到小或者从小到大排序。 main()实现数据输人,函数调用,数据格式输出, 数组排序用函数完成,排序方法不限,必须有调用排序函数的过程代码+注释
2条回答 默认 最新
- qfl_sdu 2021-05-20 10:06关注
代码如下,如有帮助,请采纳一下,谢谢。
#include <stdio.h> #define n (int)6 #define m (int)5 //n行m列数组 void SortFun(int a[][m]) { int len = n*m; //等价于一维数组的大小 int i, j; int b[n*m]; //二维数组转成一维数组 for (i = 0; i < len - 1; i++) for (j = 0; j < len - 1 - i; j++) b[i*m+j] = a[i][j]; //一维数组从小到大冒泡排序 int temp; for (i = 0; i < len - 1; i++) { for (j = 0; j < len - 1 - i; j++) { if (b[j] > b[j + 1]) { temp = b[j]; b[j] = b[j + 1]; b[j + 1] = temp; } } } //将b的数据按列赋值给a for (int i = 0;i< len; i++) { int col = i/n; int row = i%n; a[row][col] = b[i]; } } int main() { int a[6][5]={22,33,11,3,4,5,1,2,7,9,10,32,31,34,35,38,39,40,50,48,42,41,45,56,54,52,59,90,66,87}; printf("排序前:\n"); for (int i = 0; i < 6; i++) { for (int j = 0; j < 5;j++) { printf("%d ",a[i][j]); } printf("\n"); } SortFun(a); printf("排序后:\n"); for (int i = 0; i < 6; i++) { for (int j = 0; j < 5;j++) { printf("%d ",a[i][j]); } printf("\n"); } getchar(); getchar(); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 在若依框架下实现人脸识别
- ¥15 网络科学导论,网络控制
- ¥100 安卓tv程序连接SQLSERVER2008问题
- ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同