解题思路:参考题号1110题 “2^k进制数”
参考代码:

#include <stdio.h>

int a[7][7];
int b[7];//记录矩阵的每一行最多移动的次数
int n;

int max()//求出每次移动一行之后的矩阵的“列元素和”最大值
{
    int i,j,tmp,res=-1;
    for(j=0;j<n;j++)
    {
        tmp=0;
        for(i=0;i<n;i++)
            tmp +=a[i][j];
        if(tmp>res) res=tmp;
    }
    return res;
}


void move(int i)//移动矩阵第i行
{
    int k,j,tmp;
    tmp=a[i][n-1];
    for(j=n-1;j>0;j--)
        a[i][j]=a[i][j-1];
    a[i][0]=tmp;
}


int main()
{
    int i,j,k,min,m;
    while(scanf("%d",&n)&&n>0)
    {
        //初始化
        for(i=0;i<n;i++)
            for(j=0;j<n;j++)
                scanf("%d",a[i]+j);
        for(i=0;i<n;i++)
            b[i]=1;
        min=100000;

        int flag=1;
        while(flag){
            flag=0;
            for(i=n-1;i>=0;i--){
                if(b[i]<=n)
                {
                    b[i]++;
                    move(i);
                    m=max();
                    if(m<min) min=m;
                    for(k=i+1;k<n;k++)
                        b[k]=1;
                    flag=1;
                    break;
                }
            }
        }
        printf("%d\n",min);
    }
    return 0;
}


点赞(1)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 3 条评论

1203 2年前 回复TA
@Monkey 是可以多行移动的,n-i行移动一次,n-i-1也移动一次······直到n-1行移动n次
Monkey 2年前 回复TA
我有些看不懂地方就是这个循环能同时让多行移动吗,毕竟有可能答案是多行移动后的结果。而原代码似乎只是从下往上只移动一行?如果有大佬懂请私信告诉我。用户名:Monkey
?! 3年前 回复TA
刚开始看到if里面的for循环不懂,然后按照程序顺序走一遍才明白过来,但是作者思路和大部分人不一样,我们一直以为是最下面一行开始,移动一次,则上面的每一行就要移动n次,但是作者的思路却是上面的每移动一次,下面的每一行就要移动n次。如果是这样的话,那就多移动了n^n次,因为从最后一行开始移动,只有移动到第二行的时候才能算是完结。那么从最后一行移到第二行就已经完结了,但是作者的是第二行又重新做了一次全排列,相当于做了两次全排列。所以如果可以的话,尽量用递归调用,而不用这样的方法先排列到递归的结束条件再重新排一遍。