阴阳相易


私信TA

用户名:gouchao

访问量:19321

签 名:

楼上小心你的分数了,我即将爆掉你的菊花

等  级
排  名 221
经  验 6331
参赛次数 2
文章发表 18
年  龄 0
在职情况 待业
学  校
专  业

  自我简介:

疑惑:

/*
对于此题……
我把排序的代码注释掉之后,才通过了……
真的,难道是我的理解有问题?
不用考虑输入的数字不是从小到大排列好的?
*/

参考代码:

#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 人评分

  评论区

  • «
  • »