定义一个5行5列的二维数组,并动态赋值,将第3列的数组进行从小到大的排序
1个回答
展开全部
#include <stdio.h>
#include <stdlib.h>
int cmp(const void* a, const void* b)
{
return *(int*)a > *(int*)b;
}
int main()
{
int arr[5][5];
int tmp[5];
int ct = 0;
int i,j;
printf("input 25 numbers: \n");
for(i = 0; i < 5; i++)
{
for(j = 0; j < 5; j++)
{
printf("%d: ", ++ct);
scanf("%d", &arr[i][j]);
}
}
ct = 0;
printf("the array is: \n");
for(i = 0; i < 5; i++)
{
for(j = 0; j < 5; j++)
{
printf("\t%d", arr[i][j]);
if(j == 2)
tmp[ct++] = arr[i][j];
}
printf("\n");
}
ct = 0;
qsort(tmp, 5, sizeof(int), cmp);
printf("after the sort the second col, is: \n");
for(i = 0; i < 5; i++)
{
for(j = 0; j < 5; j++)
{
if(j == 2)
arr[i][j] = tmp[ct++];
printf("\t%d", arr[i][j]);
}
printf("\n");
}
printf("\n");
return 0;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |