搜索所有的路径-矩阵运算-暴力-ACM
有多个测试序列,每个测试序列第一行是一个整数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的更多相关文章
- Mine Number(搜索,暴力) ACM省赛第三届 G
Mine Number Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 Every one once played the gam ...
- 洛谷 P2196 挖地雷 & [NOIP1996提高组](搜索,记录路径)
传送门 解题思路 就是暴力!!! 没什么好说的,总之,就是枚举每一个起点,然后暴力算一遍以这个点为起点的所有路径,在算的过程中,只要比目前找到的答案更优,就有可能是最后的答案,于是就把路径更新一遍,保 ...
- 从0开始学java——JSP&Servlet——web容器搜索class的路径顺序
在web应用程序如果要用到某个类,会按照如下的顺序来搜索: 1)在WEB-INF/classes目录下搜索: 2)如果该目录下没有,则会到WEB-INF/lib目录下的jar文件中搜索: 3)如果还没 ...
- Nikita and string [思维-暴力] ACM
codeforces Nikita and string time limit per test 2 seconds memory limit per test 256 megabytes O ...
- js图的数据结构处理----邻链表,广度优先搜索,最小路径,深度优先搜索,探索时间拓扑
//邻居连表 //先加入各顶点,然后加入边 //队列 var Queue = (function(){ var item = new WeakMap(); class Queue{ construct ...
- 搜索专题:问题 E: 挑战ACM迷宫
这是往年校赛的一道题,最开始做这道题的时候还没有系统的学习过搜索,用了C语言学的回溯法尝试,毫无疑问的TLE: 学习了DFS之后,自己的剪枝功力不够,又是TLE,最后学了BFS之后,哇,终于做出来了, ...
- Java import以及Java类的搜索路径
如果你希望使用Java包中的类,就必须先使用import语句导入.import语句与C语言中的 #include 有些类似,语法为: import package1[.package2-].cl ...
- Python 学习 第十五篇:模块搜索路径和包导入
在导入自定义的模块时,除了指定模块名之外,也需要指定目录,由于Python把目录称作包,因此,这类导入被称为包导入.包导入把计算机上的目录变成Python的命名空间,而目录中所包含的子目录和模块文件则 ...
- Java知多少(9) import及Java类的搜索路径
如果你希望使用Java包中的类,就必须先使用import语句导入. import语句与C语言中的 #include 有些类似,语法为: import package1[.package2…].c ...
随机推荐
- TCP Connection Establishment and Termination
Three-Way Handshake The following scenario occurs when a TCP connection is established: The server m ...
- ssh互信自动化脚本(待更新)
1.建立一个ip,端口,用户,密码列表 [root@localhost shell-key]# cat arg_list.txt 172.16.56.215 172.16.56.215 172.16. ...
- spring框架DI(IOC)和AOP 原理及方案
http://www.blogjava.net/killme2008/archive/2007/04/20/112160.html http://www.oschina.net/code/snippe ...
- Qt对话框QDialog
QDialog是Qt中所有对话框窗口的基类 当QWidget无父组件的时候作为一个独立的窗口,有父组件的时候,将作为一个可见的部件嵌入到父组件里面. QDialog不能作为子部件嵌入到其他容器中 对话 ...
- 【设计模式 - 2】之单例模式(Singleton)
1 模式简介 单例模式在代码中是非常常用的,如线程池.数据库连接.注册表.共享资源.一些非常消耗资源的组件,等等. 单例模式主要解决如下问题: 确保一个特殊类的实例是独一无二的: 确保这个类 ...
- head first-----decorate design pattern
浅谈设计模式之------装饰者模式 首先给出装饰者模式的定义吧: 动态的将责任附加到对象上,若是要扩展功能,装饰者提供了比继承更加具有弹性的替代方案. 其中 ...
- 无法将类型“System.Collections.Generic.IEnumerable<EmailSystem.Model.TemplateInfo>”隐式转换为“System.Collections.Generic.List<EmailSystem.Model.TemplateInf
List<Model.Template> templateList = templateBLL.RecommendTemplateByOrder(modelEbay); List<M ...
- java继承分析
把java学完之后有開始了一遍突然发现对于继承还是不太理解所以就做了一个測试来分析一下 <span style="font-size:18px;">class A{ p ...
- linux下sqlite3可视化工具
1.介绍:sqlite3是linux上的小巧的数据库,一个文件就是一个数据库. 2.安装:要安装sqlite3,可以在终端提示符后运行下列命令:sudo apt-get install sqlite3 ...
- 关于 Android 进程保活,你所需要知道的一切
早前,我在知乎上回答了这样一个问题:怎么让 Android 程序一直后台运行,像 QQ 一样不被杀死?.关于 Android 平台的进程保活这一块,想必是所有 Android 开发者瞩目的内容之一.你 ...