传送门

唉考试的时候写错了两个细节调了一个多小时根本没调出来。

下来又调了半个小时才过。

其实很简单。

我们先dpdpdp出最开始最多多少个连续的aaa.

然后对于没法继续连续下去的用贪心+bfsbfsbfs来弄就行了。

技不如人,告辞。

代码:

#include<bits/stdc++.h>
using namespace std;
int n,k,mx[2005][2005],maxA;
char mp[2005][2005];
bool vis[2005][2005];
queue<pair<int,int> >q,s;
inline void dfs(int x,int y,int dep){
	if(~mx[x][y])return;
	if(x==1&&y==1)mx[x][y]=(mp[x][y]=='a');
	else{
		if(x^1)dfs(x-1,y,dep-1);
		if(y^1)dfs(x,y-1,dep-1);
		mx[x][y]=(mp[x][y]=='a')+max(mx[x-1][y],mx[x][y-1]);
	}
	if(dep<maxA)return;
	if(mx[x][y]>=dep-k){
		if(dep==maxA)q.push(make_pair(x,y));
		else if(dep>maxA){
			while(!q.empty())q.pop();
			q.push(make_pair(x,y)),maxA=dep;
		}
	}
}
int main(){
	memset(mx,-1,sizeof(mx)),scanf("%d%d",&n,&k);
	for(int i=1;i<=n;++i)scanf("%s",mp[i]+1);
	maxA=k;
	dfs(n,n,n*2-1);
	int sig=26;
	string tmp;
	for(int i=1;i<=min(maxA,n*2-1);++i)tmp=tmp+'a';
	if(maxA>=n*2-1)return cout<<tmp,0;
	if(!maxA)q.push(make_pair(1,1)),tmp=tmp+mp[1][1];
	for(int i=maxA?maxA+1:2;i<=n*2-1;++i){
		sig=26;
		while(!q.empty()){
			pair<int,int>t=q.front();
			q.pop();
			int x=t.first,y=t.second,i,j;
			i=x+1,j=y;
			if(i<=n&&!vis[i][j]){
				vis[i][j]=1;
				if(mp[i][j]-'a'==sig)s.push(make_pair(i,j));
				else if(mp[i][j]-'a'<sig){
					while(!s.empty())s.pop();
					s.push(make_pair(i,j)),sig=mp[i][j]-'a';
				}
			}
			i=x,j=y+1;
			if(j<=n&&!vis[i][j]){
				vis[i][j]=1;
				if(mp[i][j]-'a'==sig)s.push(make_pair(i,j));
				else if(mp[i][j]-'a'<sig){
					while(!s.empty())s.pop();
					s.push(make_pair(i,j)),sig=mp[i][j]-'a';
				}
			}
		}
		tmp=tmp+(char)(sig+'a');
		while(!s.empty())q.push(s.front()),s.pop();
	}
	cout<<tmp;
	return 0;
}

2018.10.21 codeforces1071B. Minimum path(dp+贪心+bfs)的更多相关文章

  1. 2018.10.21 codeforces1071A. Cram Time(贪心构造)

    传送门 直接先看最多能够凑出几个. 然后可以得到一个结论就是如果保证所有页数之和是小于等于A+BA+BA+B的一定都对应着一种合法方案. 如何构造? 我们对于第一天的AAA个小时,从大向小选,如果当前 ...

  2. POI 2018.10.21

    [POI2008]TRO-Triangles https://www.cnblogs.com/GXZlegend/p/7509699.html 平面上有N个点. 求出所有以这N个点为顶点的三角形的面积 ...

  3. 2018.10.19浪在ACM 集训队第一次测试赛

    2018.10.19浪在ACM 集训队第一次测试赛 待参考资料: [1]:https://blog.csdn.net/XLno_name/article/details/78559973?utm_so ...

  4. 【2018.10.20】CXM笔记(思维)

    1. 给你个环状字符串,问从哪个地方拆开能使它的字典序最小. 先预处理任意子串的哈希值. 然后枚举拆点,将它与当前最优的拆点比较谁更优(就是从哪拆的字典序更小),具体方法是二分+哈希找出两串最长的相同 ...

  5. [LeetCode] Unique Paths && Unique Paths II && Minimum Path Sum (动态规划之 Matrix DP )

    Unique Paths https://oj.leetcode.com/problems/unique-paths/ A robot is located at the top-left corne ...

  6. Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum)

    Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum) 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. ...

  7. 退役前的记录(2018.10.14-NOIP2018)

    退役前的记录 诸位好,我是\(CJ\)最菜的\(Oier\),已经是\(G2\)的老年选手了,不知道什么时候就会退役了,总之\(G1\ double\)的机会已经没有了,去年因为联赛失利而止步,而今年 ...

  8. 2018.10.20 2018-2019 ICPC,NEERC,Southern Subregional Contest(Online Mirror, ACM-ICPC Rules)

    i207M的“怕不是一个小时就要弃疗的flag”并没有生效,这次居然写到了最后,好评=.= 然而可能是退役前和i207M的最后一场比赛了TAT 不过打得真的好爽啊QAQ 最终结果: 看见那几个罚时没, ...

  9. 刷题64. Minimum Path Sum

    一.题目说明 题目64. Minimum Path Sum,给一个m*n矩阵,每个元素的值非负,计算从左上角到右下角的最小路径和.难度是Medium! 二.我的解答 乍一看,这个是计算最短路径的,迪杰 ...

随机推荐

  1. 视频地址blog加密

    /* JS部分 没处理兼容什么的 */ var id='<?php echo $_GET['id'];?>'; var video = document.getElementById(&q ...

  2. mysql 集群 数据同步

    mysql集群配置在网站负载均衡中是必不可少的: 首先说下我个人准备的负载均衡方式: 1.通过nginx方向代理来将服务器压力分散到各个服务器上: 2.每个服务器中代码逻辑一样: 3.通过使用redi ...

  3. Redis主从复制原理

    前言: 和MySQL主从复制的原因一样,Redis虽然读取写入的速度都特别快,但是也会产生读压力特别大的情况.为了分担读压力,Redis支持主从复制,Redis的主从结构可以采用一主多从或者级联结构, ...

  4. svn更新代码时控制台出现的英文字母表示什么意思

    U:表示从服务器收到文件更新了 G:表示本地文件以及服务器文件都已经更新,而且成功的合并了 A:表示有文件或者目录添加到工作目录 R:表示文件或者目录被替换了 C:表示文件的本地修改和服务器修改发生冲 ...

  5. MySQLReport

    简介: MySQLReport 一.安装 shell > yum -y install mysqlreport perl-DBD-MySQL 二.使用 shell > mysqlrepor ...

  6. pipeenv error

    [root@mhc tmp]# pipenv --python 3.6Creating a virtualenv for this project…Using /root/python3/bin/py ...

  7. Autopilot Pattern Redis

    https://github.com/autopilotpattern/redis Architecture 正在运行的群集包括以下组件: Redis :我们使用的是Redis 3.2. Redis ...

  8. springmvc el表达式取值顺序问题

    最近遇到一个问题,两次访问同一个controler, 第二次根据判断条件,明明没有设置model的值,在jsp中通过${data}还是能取到值,最后找到原因是 我为了能够加快响应速度,在session ...

  9. Ubuntu 16.04中VirtualBox 5.1使用U盘/USB设备的方法

    环境: Ubuntu 16.04 LTS VirtualBox 5.1.26 r118224 虚拟机系统:Windows 7 SP1 64 安装扩展: 在这里下载:(自己注意版本好,版本不匹配安装不成 ...

  10. pairs

    pairs http://acm.hdu.edu.cn/showproblem.php?pid=5178 Time Limit: 2000/1000 MS (Java/Others)    Memor ...