2018.10.21 codeforces1071B. Minimum path(dp+贪心+bfs)
传送门
唉考试的时候写错了两个细节调了一个多小时根本没调出来。
下来又调了半个小时才过。
其实很简单。
我们先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)的更多相关文章
- 2018.10.21 codeforces1071A. Cram Time(贪心构造)
传送门 直接先看最多能够凑出几个. 然后可以得到一个结论就是如果保证所有页数之和是小于等于A+BA+BA+B的一定都对应着一种合法方案. 如何构造? 我们对于第一天的AAA个小时,从大向小选,如果当前 ...
- POI 2018.10.21
[POI2008]TRO-Triangles https://www.cnblogs.com/GXZlegend/p/7509699.html 平面上有N个点. 求出所有以这N个点为顶点的三角形的面积 ...
- 2018.10.19浪在ACM 集训队第一次测试赛
2018.10.19浪在ACM 集训队第一次测试赛 待参考资料: [1]:https://blog.csdn.net/XLno_name/article/details/78559973?utm_so ...
- 【2018.10.20】CXM笔记(思维)
1. 给你个环状字符串,问从哪个地方拆开能使它的字典序最小. 先预处理任意子串的哈希值. 然后枚举拆点,将它与当前最优的拆点比较谁更优(就是从哪拆的字典序更小),具体方法是二分+哈希找出两串最长的相同 ...
- [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 ...
- Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum)
Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum) 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. ...
- 退役前的记录(2018.10.14-NOIP2018)
退役前的记录 诸位好,我是\(CJ\)最菜的\(Oier\),已经是\(G2\)的老年选手了,不知道什么时候就会退役了,总之\(G1\ double\)的机会已经没有了,去年因为联赛失利而止步,而今年 ...
- 2018.10.20 2018-2019 ICPC,NEERC,Southern Subregional Contest(Online Mirror, ACM-ICPC Rules)
i207M的“怕不是一个小时就要弃疗的flag”并没有生效,这次居然写到了最后,好评=.= 然而可能是退役前和i207M的最后一场比赛了TAT 不过打得真的好爽啊QAQ 最终结果: 看见那几个罚时没, ...
- 刷题64. Minimum Path Sum
一.题目说明 题目64. Minimum Path Sum,给一个m*n矩阵,每个元素的值非负,计算从左上角到右下角的最小路径和.难度是Medium! 二.我的解答 乍一看,这个是计算最短路径的,迪杰 ...
随机推荐
- Python selenium的js扩展实现
python写的数据采集,对一般有规律的页面用 urllib2 + BeautifulSoup + 正则就可以搞定. 但是有些页面的内容是通过js生成,或者通过js跳转的,甚至js中还加入几道混淆机制 ...
- 关于RabbitMQ以及RabbitMQ和Spring的整合
转自:https://www.cnblogs.com/s648667069/p/6401463.html 基本概念 RabbitMQ是流行的开源消息队列系统,用erlang语言开发.RabbitMQ是 ...
- objective C, parse json时注意事项
例: dict为从API请求返回的json调用 NSJSONSerialization JSONObjectWithData:方法得到的NSDictionary实例. 当执行以下语句时linkStri ...
- postgresql 的操作
基本操作: \o /tmp/11.txt ,查询结果输出到文件 \d 查询table结构 \x 切换显示方式 postgresql中可以导出某个sql的执行结果到文件中,方法是在psql中首先执行\o ...
- jenkins systemctl启动失败
centos yum或者rpm安装jenkins后起不来 vi /etc/init.d/jenkins candidates="/usr/local/jdk1.8.0_171/bin/jav ...
- 集合赋值及for循环删除符合条件的元素
一.Java语言中ArrayList对象能直接赋值给另一个ArrayList对象吗? https://zhidao.baidu.com/question/399214655.html ArrayLis ...
- 各种id生成策略
package com.taotao.utils; import java.util.Random; /** * 各种id生成策略 */ public class IDUtils { /** * 图片 ...
- Android模拟器内安装应用
一.通过apk安装器安装应用 1.下载apk安装器(网上随便搜一个就可以) 2.下载要测试的应用的apk,我这里下载的是微信的apk 3.打开apk安装器,点击右上角的Devices选择要安装到的设备 ...
- (转) Ringbuffer为什么这么快?
原文地址:http://ifeve.com/ringbuffer/ 最近,我们开源了LMAX Disruptor,它是我们的交易系统吞吐量快(LMAX是一个新型的交易平台,号称能够单线程每秒处理数百万 ...
- mybatis什么时候需要声明jdbcType?
经常会见到以下两种写法:1. #{bookId}2. #{bookId,jdbcType=INTEGER}一般情况下,两种写法都可以.它们都可以获取Dao层传递过来的参数.但是,当传入的参数为null ...