c语言求助,急,我这有什么不对
输一个二维数组a,进行排序,数值小的数优先级大于数值高的数,且行元素的大大于优先级大于列元素的优先级,如果行元素相同,则比较列元素。例:(3,7)优先于(4,0);(1,0)优先于(1,1)要求:1.n>=5
2.输出优先级第2的数
3.不能出现两组一样的元素
例:
输入:a={0,1,2,3,4,5,6,7,8,9}
输出:2,3
#include <stdio.h>
int cmp(const void *a,const void *b)
{
int *a1=(int*)a;
int *b1=(int*)b;
if(a1>b1)
return 1;
else if(a1<b1)
return -1;
else if(a1>b1)
return 1;
else if(a1<b1)
return -1;
return 0;
}
int cmp1(const void *a,const void *b)
{
return *(int*)a-*(int*)b;
}
int main()
{
int n;
scanf("%d",&n);
if(n<5)
return 0;
int a, *a1=(int*)a,i;
int *a2=(int*)a;
for(i=0;i<2*n;i+=1 )
scanf("%d",a1+i);
qsort(a2,n,sizeof(int ),cmp);
for(i=0;i<2*n;i+=1)
printf("%d",a1);
return 0;
} 发代码请用代码格式 #include <stdio.h>
#include<stdlib.h>
int cmp(void* a,void *b)
{
int *a1=(int*)a;
int *b1=(int*)b;
if(a1>b1)return 1;
else if(a1<b1)return -1;
else if(a1>b1) return 1;
else if(a1<b1) return -1;
return 0;
}
int cmp1(void* a,void *b)
{
return *(int*)a-*(int*)b;
}
int main()
{
int n;
scanf("%d",&n);
if(n<5)return 0;
int a,*a1=(int*)a;
long long *a2=(long long*)a;
for(int i=0;i<2*n;i+=1 )scanf("%d",a1+i);
/*qsort(a1,2*n,sizeof(int),cmp1);
for(int i=0;i<2*n;i+=1)printf("%d",a1);*/
qsort(a2,n,sizeof(long long ),cmp);
//for(int i=0;i<2*n;i+=1)printf("%d",a1);
printf("%d,%d\n",a,a);
return 0;
} 问题出在你的 qsort() 里,你设成每个元素大小为 int 长度了,但其实每个元素大小是两个 int 大小,也就是 long long
#include <stdio.h>
#include <stdlib.h>
int cmp(const void* a, const void* b) {
return !(*(int*)a - *(int*)b) ? *((int*)a + 1) - *((int*)b + 1) : *(int*)a - *(int*)b;
}
int main(void) {
int arr = { {1, 9}, {1, 4}, {3, 4}, {3, 6}, {2, 9} };
qsort(arr, 5, sizeof(long long), cmp);
for (int i = 0; i < 5; ++i) {
printf("%d %d\n", arr, arr);
}
return 0;
}
页:
[1]