给定一个n*n整数矩阵,定义对I行的SHIFT操作( 0 <= i < n ),是将第I行所有元素都右移一位,最右边的移到最左边。
你可以对任意行进行任意次SHIFT操作,使得:
max0<=j< n{Cj|Cj=Σ0<=i< nAi,j}最小化。
输入:

有多个测试序列,每个测试序列第一行是一个整数n(1<=n<=7),表明矩阵的阶。后面n行每行n个整数,表示矩陈元素。n=-1表示输入结束,无需处理。

2
4 6
3 7
3
1 2 3
4 5 6
7 8 9
-1
输出:

最小值

11
15
解题思路:

不需要特殊的数据结构;从题目描述,数据的规模不大(n<8),算法采用暴力搜索。所有的可能情况都找出来:每一行都可能移0到n-1步,所以总的情况有nn 种,对每种情况进行编号。如n=7时,7进制的0123456表示第一行不动,第二行移动一次……

#include <stdio.h>
#include <math.h> int n;
int matrix[128][128];
int s[128];
void inttoseries(int i,int *s)
{
int j,k;
//函数将序号化为移动的序列
for(k=0,j=i;k<n-1;++k)
{
//二维数组并未移动,s[k]记录的偏移量,第一行未移动
s[k]=j%n;j/=n;
}
} int maxcolumn(int *s)
{
int max,i,j,temp;
// 函数返回在指定移动情况下的最大值。
for(max=matrix[0][0],i=1;i<n;++i)
max+=matrix[i][s[i-1]]; //计算第1列的和
for(i=1;i<n;++i)
{
for(j=1,temp=matrix[0][i];j<n;++j)
temp+=matrix[j][(s[j-1]+i)%n]; //计算第 i 列的和
if(temp>max)max=temp;
} return max;
} int main(){
int min,i,j,temp;
while(scanf("%d",&n),n+1)
{
for(i = 0;i<n;i++){
for(j = 0;j<n;j++){
scanf("%d",&matrix[i][j]);
}
}
inttoseries(0,s);
min=maxcolumn(s);
int k = (int)pow(n,n); //所有可能的情况共有n^n种
for(i=1;i<k;++i) //循环将遍历所有移动情况
{
inttoseries(i,s); //将i转换成移动编码s
temp=maxcolumn(s); //计算按照移动编码s进行移动所能取得的最大值
if(temp<min)min=temp;
}
printf("%d\n",min);
}
return 0;
}

搜索所有的路径-矩阵运算-暴力-ACM的更多相关文章

  1. Mine Number(搜索,暴力) ACM省赛第三届 G

    Mine Number Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 Every one once played the gam ...

  2. 洛谷 P2196 挖地雷 & [NOIP1996提高组](搜索,记录路径)

    传送门 解题思路 就是暴力!!! 没什么好说的,总之,就是枚举每一个起点,然后暴力算一遍以这个点为起点的所有路径,在算的过程中,只要比目前找到的答案更优,就有可能是最后的答案,于是就把路径更新一遍,保 ...

  3. 从0开始学java——JSP&Servlet——web容器搜索class的路径顺序

    在web应用程序如果要用到某个类,会按照如下的顺序来搜索: 1)在WEB-INF/classes目录下搜索: 2)如果该目录下没有,则会到WEB-INF/lib目录下的jar文件中搜索: 3)如果还没 ...

  4. Nikita and string [思维-暴力] ACM

    codeforces Nikita and string time limit per test   2 seconds memory limit per test   256 megabytes O ...

  5. js图的数据结构处理----邻链表,广度优先搜索,最小路径,深度优先搜索,探索时间拓扑

    //邻居连表 //先加入各顶点,然后加入边 //队列 var Queue = (function(){ var item = new WeakMap(); class Queue{ construct ...

  6. 搜索专题:问题 E: 挑战ACM迷宫

    这是往年校赛的一道题,最开始做这道题的时候还没有系统的学习过搜索,用了C语言学的回溯法尝试,毫无疑问的TLE: 学习了DFS之后,自己的剪枝功力不够,又是TLE,最后学了BFS之后,哇,终于做出来了, ...

  7. Java import以及Java类的搜索路径

    如果你希望使用Java包中的类,就必须先使用import语句导入.import语句与C语言中的 #include 有些类似,语法为:    import package1[.package2-].cl ...

  8. Python 学习 第十五篇:模块搜索路径和包导入

    在导入自定义的模块时,除了指定模块名之外,也需要指定目录,由于Python把目录称作包,因此,这类导入被称为包导入.包导入把计算机上的目录变成Python的命名空间,而目录中所包含的子目录和模块文件则 ...

  9. Java知多少(9) import及Java类的搜索路径

    如果你希望使用Java包中的类,就必须先使用import语句导入. import语句与C语言中的 #include 有些类似,语法为:    import package1[.package2…].c ...

随机推荐

  1. [转]让程序在崩溃时体面的退出之SEH+Dump文件

    原文地址:http://blog.csdn.net/starlee/article/details/6649605 在我上篇文章<让程序在崩溃时体面的退出之SEH>中讲解了SEH中try/ ...

  2. record

    http://www.cnblogs.com/90zeng/p/python_translation.html http://www.cnblogs.com/netfocus/p/4478094.ht ...

  3. 广州Uber优步司机奖励政策(1月25日~1月31日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  4. windows 下文件上传到fastdfs

    php.ini 配置 [fastdfs]; the base pathfastdfs_client.base_path = D:/tmp ; connect timeout in seconds; d ...

  5. Spring IOC配置与应用

    1.     FAQ:不给提示: a)     window – preferences – myeclipse – xml – xml catalog b)     User Specified E ...

  6. 分享一个很好看的WPF界面

    今天在http://www.iopenworks.com/Products/ProductDetails/Introduction?proID=386 上面看到的,先mark下来...... 地址:h ...

  7. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(45)-工作流设计-设计步骤

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(45)-工作流设计-设计步骤 系列目录 步骤设计很重要,特别是规则的选择. 我这里分为几个规则 1.按自行 ...

  8. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(19)-权限管理系统-用户登录

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(19)-权限管理系统-用户登录 我们之前做了验证码,登录界面,却没有登录实际的代码,我们这次先把用户登录先 ...

  9. C# 自动登录网页,浏览页面【转载】

    需求:客户的数据同时存在在另外一个不可控的系统中,需要和当前系统同步. 思路:自动登录另外一个系统,然后抓取数据,同步到本系统中. 技术点:模拟用户登录:保存登录状态:抓取数据 /// <sum ...

  10. jboss 7 as1 日志配置

    原文地址:https://docs.jboss.org/author/display/AS71/Logging+Configuration Overview The overall server lo ...