疑惑:
/* 对于此题…… 我把排序的代码注释掉之后,才通过了…… 真的,难道是我的理解有问题? 不用考虑输入的数字不是从小到大排列好的? */
参考代码:
#define LEN 4 #include <stdio.h> void sort(int a[]); void print(int a[]); int main(void){ int n; scanf("%d",&n); int a[n][LEN]; int i = 0; while(i<n){ scanf("%d%d%d%d",&a[i][0],&a[i][1],&a[i][2],&a[i][3]); i++; } i = 0; while(i<n){ // sort(a[i]); print(a[i]); i++; if(i<n) printf("\n"); } return 0; } void sort(int a[]){ int i,j; int t = 0; int min = a[t]; for(i = 0;i<LEN-1;i++){ min = a[i]; t = i; for(j = i+1;j<LEN;j++){ if(a[j] < min){ min = a[j]; t = j; } } if(t != i){ a[t] = a[i]; a[i] = min; } } } void print(int a[]){ int i,j,k,l; int count = 0; for(i = 0;i<LEN;i++){ for(j = 0;j<LEN;j++){ for(k = 0;k<LEN;k++){ for(l = 0;l<LEN;l++){ if(l != i && l != j && l != k && k != i && k != j && j != i){ printf("%d",a[i]*1000+a[j]*100+a[k]*10+a[l]); count++; if(count < 6) printf(" "); else { count = 0; printf("\n"); } } } } } } }
0.0分
0 人评分