如何用c语言给输入的二维数组每一行排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何用c语言给输入的二维数组每一行排序相关的知识,希望对你有一定的参考价值。

可以用stdlib.h中的qsort函数
如果是int a[10][10]的话
排序第i行
qsort(a[i],10,sizeof(int),comp);
就可以了,comp是一个比较函数
int comp(const void *m1, const void *m2)
return *(int*)m1-*(int*)m2;

这样就可以排序了,如果要反序,就将comp中的m1和m2互换,可以试试,如果不对可以Hi我
参考技术A #include <stdio.h>
void main()

int a[3][4],i,j,t,m,x;
printf("输入一3×4二维整型数组:\n");
for(i=0;i<3;i++)
for(j=0;j<4;j++)
scanf("%d",*(a+i)+j);
for(x=1;x<5;x++)
for(i=0;i<3;i++)

for(t=0;t<3;t++)
if(*(*(a+i)+t+1)<*(*(a+i)+t))

m=*(*(a+i)+t+1);
*(*(a+i)+t+1)=*(*(a+i)+t);
*(*(a+i)+t)=m;


printf("每行按从小到大的排序后为:\n");
for(i=0;i<3;i++)

for(j=0;j<4;j++)
printf("%6d",*(*(a+i)+j));
printf("\n");

本回答被提问者采纳
参考技术B 这是最基本的排序算法

依次比较两个把大的放在前面

循环
循环
就可以了

在C语言中如何用把二维数组中的一行贼给一维数组?

参考技术A 按列遍历,并输出到一维数组即可.

void covert(int a[M][N], b[M*N]) int i,j,n; for(i = n = 0; i < N; i++) for(j = 0; j < M; j ++) b[n++] = a[j][i];
参考技术B int i,j,a[3][4],b[12];
int n=0;
for(i=0;i<3;i++)
for(j=0;j<4;j++)

b[n++]=a[i][j];


或者用这个,memcpy(b , a[0],16); 后面的16表示4个整形,16个字节,但是我怕你搞错,还是走循环,嵌套赋值吧
参考技术C 一个一个复制
for ( int i = 0; i < 3; ++i )
b[i] = a[0][i];
//数组不支持直接拷贝。 不能整体赋值,这点不像结构体。

以上是关于如何用c语言给输入的二维数组每一行排序的主要内容,如果未能解决你的问题,请参考以下文章

在C语言中如何用把二维数组中的一行贼给一维数组?

如何用VB给二维数组排序

C语言中如何取二维数组的一行(一列)?

c语言二维数组 赋值

C语言二维数组问题

C语言实现一个可变长的二维数组