HDU 5402 Travelling Salesman Problem (构造)(好题)
大致题意:n*m的非负数矩阵,从(1,1) 仅仅能向四面走,一直走到(n,m)为终点。路径的权就是数的和。输出一条权值最大的路径方案
思路:因为这是非负数,要是有负数就是神题了,要是n,m中有一个是奇数。显然能够遍历。要是有一个偶数。能够绘图发现,把图染成二分图后,(1,1)为黑色,总能有一种构造方式能够仅仅绕过不论什么一个白色的点。然后再遍历其它点。而绕过黑色的点必定还要绕过两个白色点才干遍历所有点,这是绘图发现的。所以找一个权值最小的白色点绕过就能够了,
题解给出了证明:
如果n,mn,m都为偶数,那么讲棋盘黑白染色。如果(1,1)(1,1)和(n,m)(n,m)都为黑色,那么这条路径中黑格个数比白格个数多11,而棋盘中黑白格子个数同样。所以必定有一个白格不会被经过。所以选择白格中权值最小的不经过。
- //#pragma comment(linker, "/STACK:1024000000,1024000000")
- #include <iostream>
- #include <cstring>
- #include <cmath>
- #include <queue>
- #include <stack>
- #include <map>
- #include <set>
- #include <string>
- #include <vector>
- #include <cstdio>
- #include <ctime>
- #include <bitset>
- #include <algorithm>
- #define SZ(x) ((int)(x).size())
- #define ALL(v) (v).begin(), (v).end()
- #define foreach(i, v) for (__typeof((v).begin()) i = (v).begin(); i != (v).end(); ++ i)
- #define reveach(i, v) for (__typeof((v).rbegin()) i = (v).rbegin(); i != (v).rend(); ++ i)
- #define REP(i,n) for ( int i=1; i<=int(n); i++ )
- #define rep(i,n) for ( int i=0; i< int(n); i++ )
- using namespace std;
- typedef long long ll;
- #define X first
- #define Y second
- typedef pair<int,int> pii;
- template <class T>
- inline bool RD(T &ret) {
- char c; int sgn;
- if (c = getchar(), c == EOF) return 0;
- while (c != '-' && (c<'0' || c>'9')) c = getchar();
- sgn = (c == '-') ? -1 : 1;
- ret = (c == '-') ?
- 0 : (c - '0');
- while (c = getchar(), c >= '0'&&c <= '9') ret = ret * 10 + (c - '0');
- ret *= sgn;
- return 1;
- }
- template <class T>
- inline void PT(T x) {
- if (x < 0) {
- putchar('-');
- x = -x;
- }
- if (x > 9) PT(x / 10);
- putchar(x % 10 + '0');
- }
- const int N = 123;
- int mp[N][N];
- int main(){
- int n,m;
- while(~scanf("%d%d",&n,&m)){
- int sum = 0;
- memset(mp,0,sizeof(mp));
- REP(i,n) REP(j,m) RD(mp[i][j]), sum += mp[i][j];
- if( (n&1)||(m&1) ){
- PT(sum);puts("");
- if( n&1 ){
- REP(r,n){
- if( r&1 ) REP(i,m-1) putchar('R');
- else REP(i,m-1) putchar('L');
- if( r != n) putchar('D');
- }
- }else{
- REP(c,m){
- if( c&1 ) REP(i,n-1) putchar('D');
- else REP(i,n-1) putchar('U');
- if( c != m) putchar('R');
- }
- }
- }else{
- int minn = 1LL<<30;
- int sx,sy;
- REP(x,n) REP(y,m){
- if( (x+y)&1 ){
- if( mp[x][y] < minn) minn = mp[x][y], sx = x,sy = y;
- }
- }
- printf("%d\n",sum-minn);
- bool ok = 0;
- REP(y,m){
- if( (y-1)/2+1 == (sy-1)/2+1){
- ok = 1;
- bool rgt = 1;
- REP(x,n){
- if( x == sx) {
- if( x != n) putchar('D');
- continue;
- }
- if( rgt) putchar('R');
- else putchar('L');
- if( x != n) putchar('D');
- rgt = !rgt;
- }
- y++;
- }else{
- if( ((y&1)&&ok==0) || ((y%2 == 0)&&ok) ){
- REP(x,n-1) putchar('D');
- }else{
- REP(x,n-1) putchar('U');
- }
- }
- if( y != m) putchar('R');
- }
- }
- puts("");
- }
- }
Travelling Salesman Problem
Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 864 Accepted Submission(s): 313
Special Judge
and m columns.
There is a non-negative number in each cell. Teacher Mai wants to walk from the top left corner (1,1) to
the bottom right corner (n,m).
He can choose one direction and walk to this adjacent cell. However, he can't go out of the maze, and he can't visit a cell more than once.
Teacher Mai wants to maximize the sum of numbers in his path. And you need to print this path.
For each test case, the first line contains two numbers n,m(1≤n,m≤100,n∗m≥2).
In following n lines,
each line contains m numbers.
The j-th
number in the i-th
line means the number in the cell (i,j).
Every number in the cell is not more than 104.
In the next line you should print a string consisting of "L","R","U" and "D", which represents the path you find. If you are in the cell (x,y),
"L" means you walk to cell (x,y−1),
"R" means you walk to cell (x,y+1),
"U" means you walk to cell (x−1,y),
"D" means you walk to cell (x+1,y).
3 3 2 3 3 3 3 3 3 3 2
25 RRDLLDRR
HDU 5402 Travelling Salesman Problem (构造)(好题)的更多相关文章
- 构造 - HDU 5402 Travelling Salesman Problem
Travelling Salesman Problem Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=5402 Mean: 现有一 ...
- HDU 5402 Travelling Salesman Problem (模拟 有规律)(左上角到右下角路径权值最大,输出路径)
Travelling Salesman Problem Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (J ...
- HDU 5402 Travelling Salesman Problem(棋盘染色 构造 多校啊)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5402 Problem Description Teacher Mai is in a maze wit ...
- hdu 5402 Travelling Salesman Problem(大模拟)
Problem Description Teacher Mai ,) to the bottom right corner (n,m). He can choose one direction and ...
- HDU 5402 Travelling Salesman Problem(多校9 模拟)
题目链接:pid=5402">http://acm.hdu.edu.cn/showproblem.php?pid=5402 题意:给出一个n×m的矩阵,位置(i.j)有一个非负权值. ...
- HDU 5402 : Travelling Salesman Problem
题目大意:n*m的格子,从左上角走到右下角,每个格子只能走一遍,每个格子上有一个非负数,要让途径的数字和最大,最后要输出路径 思路:显然茹果n,m有一个是奇数的话所有格子的数字都能被我吃到,如果都是偶 ...
- hdu 5402 Travelling Salesman Problem (技巧,未写完)
题意:给一个n*m的矩阵,每个格子中有一个数字,每个格子仅可以走一次,问从(1,1)走到(n,m) 的路径点权之和. 思路: 想了挺久,就是有个问题不能短时间证明,所以不敢下手. 显然只要n和m其中一 ...
- HDU 5402(Travelling Salesman Problem-构造矩阵对角最长不相交路径)
Travelling Salesman Problem Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (J ...
- HDOJ 5402 Travelling Salesman Problem 模拟
行数或列数为奇数就能够所有走完. 行数和列数都是偶数,能够选择空出一个(x+y)为奇数的点. 假设要空出一个(x+y)为偶数的点,则必须空出其它(x+y)为奇数的点 Travelling Salesm ...
随机推荐
- Pycharm 设置python文件自动生成头部信息模板
设置头部信息路径: 打开File—Settings—Editor—File and Code Templates—Python Script 输入要自动生成的头部信息模板 这样,新建py文件就会自动生 ...
- 共享win7ip,虚拟机nat模式连接,电脑重启之后,无法连接
问题原因:VMware NAT Service没有设置为开机启动 解决办法: 1.按win+r,输入services.msc,点击确定: 2.服务窗口中找到VMware NAT Service,双击: ...
- https://quotefancy.com/ 经典句子(英语) 真是特别好~
https://quotefancy.com/ 经典句子(英语)
- ie11 突然不能加载外部css 很神奇 头部改为 <!DOCTYPE> <html>
<!DOCTYPE html> <html> 改为 <!DOCTYPE> <html> OK了
- 输出所有进程和进程ID
#include <windows.h> #include <tlhelp32.h> #include <tchar.h> #include <stdio.h ...
- slover层解读
void Solver<Dtype>::UpdateSmoothedLoss(Dtype loss, int start_iter, int average_loss) { if (los ...
- 四、spring中高级装配(2)
这个是接着上一篇写的,这章内容较多,分开来记录一下... 三.处理自动装配的歧义性 自动装配让spring完全负责bean引用注入到构造参数和属性中,不过,仅有一个bean匹配所需的结果时,自动装配才 ...
- AC手动机 [原创]
题目背景 Monster_Qi 又双叒叕拿到了rank1! 在开心之余他决定帮助蒟蒻floatiy拿到合适的排名. 题目描述 已知考试有n道题,每道题有num个测试点,有m个人 b[x,i,j](01 ...
- 模板BSGS(SDOI2011计算器) 模板EXBSGS
BSGS和EXBSGS是OI中用于解决A^xΞB(mod C)的常用算法. 1.BSGS BSGS用于A,C互质的情况. 令m=sqrt(C),此时x可表示为i*m+j. 式中i和j都<=sqr ...
- python 列表(二)
列表的其他操作 count 用于统计列表中某个元素出现的次数 Eg: extend 把一个列表添加到另一个列表里面 Index 输出元素的位置即根据内容索引位置 Reverse 把列表元素的位置倒过 ...