和FallDream dalao一起从学长那借了个小号打Div2,他切ABE我做CD,我这里就写下CD题解,剩下的戳这里

AC:All Rank:33 小号Rating:1539+217->1756

C.Alyona and Spreadsheet

题目大意:给出一个n*m的数字矩阵a,k次询问,每次给li,ri,求是否有一列的a[li][j],a[li+1][j],...a[ri][j]组成一个不下降序列。(n*m<=100,000,k<=100,000)

思路:O(n*m)扫一遍可以预处理出每个ri最小的li,我菜,写了线段树。

#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
using namespace std;
inline int read()
{
int x=;char c;
while((c=getchar())<''||c>'');
for(;c>=''&&c<='';c=getchar())x=(x<<)+(x<<)+c-'';
return x;
}
#define MN 100000
#define N 131072
#define INF 0x7FFFFFFF
vector<int> v[MN+];
vector<pair<int,int> > q[MN+];
int t[N*+],ans[MN+];
void change(int k,int x){for(t[k+=N]=x;k>>=;)t[k]=min(t[k<<],t[(k<<)+]);}
int main()
{
int n,m,k,i,j;
n=read();m=read();
for(i=;i<=m;++i)v[].push_back(INF);
for(i=;i<=n;++i)v[i].push_back();
for(i=;i<=n;++i)for(j=;j<=m;++j)v[i].push_back(read());
for(k=read(),i=;i<k;++i)j=read(),q[read()].push_back(make_pair(j,i));
memset(t,,sizeof(t));
for(i=;i<=n;++i)
{
for(j=;j<=m;++j)if(v[i][j]<v[i-][j])change(j,i);
for(j=;j<q[i].size();++j)ans[q[i][j].second]=(t[]<=q[i][j].first);
}
for(i=;i<k;++i)puts(ans[i]?"Yes":"No");
}

D.

题目大意:给N个字符串,从中删掉最少的字符使得字符串按字典序排序。(字符数量<=500,000)

思路:我写了个分治……solve(l,r,p)表示第l个到第r个前p-1个都一样,从后往前找到第一个s[i][p]>s[i+1][p],把第l个到第i个p以后都截掉,然后按第p个字符分成几块继续分治。其实只要从最后一个往前贪心删掉就可以了。

#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
#define MN 500000
#define INF 0x7FFFFFFF
string s[MN+];
int L[MN+];
int C(int x,int y){return y<=L[x]?s[x][y]:;}
void solve(int l,int r,int p)
{
int i,j,mn=INF;
for(i=r;i>=l;--i)
{
if(C(i,p)>mn)L[i]=p-;
mn=min(mn,C(i,p));
}
for(i=l;i<=r;i=j)
{
for(j=i;j<=r&&C(i,p)==C(j,p);++j);
if(C(i,p))solve(i,j-,p+);
}
}
int main()
{
int n,i,j;
cin>>n;
for(i=;i<=n;++i)
{
cin>>s[i];
L[i]=s[i].size()-;
}
solve(,n,);
for(i=;i<=n;++i,puts(""))for(j=;j<=L[i];++j)putchar(s[i][j]);
}

Codeforces Round #401 (Div. 2)的更多相关文章

  1. Codeforces Round #401 (Div. 2) 离翻身就差2分钟

    Codeforces Round #401 (Div. 2) 很happy,现场榜很happy,完全将昨晚的不悦忘了.终判我校一片惨白,小董同学怒怼D\E,离AK就差一个C了,于是我AC了C题还剩35 ...

  2. Codeforces Round #401 (Div. 2) C Alyona and Spreadsheet —— 打表

    题目链接:http://codeforces.com/contest/777/problem/C C. Alyona and Spreadsheet time limit per test 1 sec ...

  3. Codeforces Round #401 (Div. 2) D Cloud of Hashtags —— 字符串

    题目链接:http://codeforces.com/contest/777/problem/D 题解: 题意:给出n行字符串,对其进行字典序剪辑.我自己的想法是正向剪辑的,即先对第一第二个字符串进行 ...

  4. D Cloud of Hashtags Codeforces Round #401 (Div. 2)

    Cloud of Hashtags [题目链接]Cloud of Hashtags &题意: 给你一个n,之后给出n个串,这些串的总长度不超过5e5,你要删除最少的单词(并且只能是后缀),使得 ...

  5. C Alyona and Spreadsheet Codeforces Round #401(Div. 2)(思维)

    Alyona and Spreadsheet 这就是一道思维的题,谈不上算法什么的,但我当时就是不会,直到别人告诉了我,我才懂了的.唉 为什么总是这么弱呢? [题目链接]Alyona and Spre ...

  6. Codeforces Round #401 (Div. 2) A,B,C,D,E

    A. Shell Game time limit per test 0.5 seconds memory limit per test 256 megabytes input standard inp ...

  7. Codeforces Round #401 (Div. 2) A B C 水 贪心 dp

    A. Shell Game time limit per test 0.5 seconds memory limit per test 256 megabytes input standard inp ...

  8. Codeforces Round #401 (Div. 1) C(set+树状数组)

    题意: 给出一个序列,给出一个k,要求给出一个划分方案,使得连续区间内不同的数不超过k个,问划分的最少区间个数,输出时将k=1~n的答案都输出 比赛的时候想的有点偏,然后写了个nlog^2n的做法,T ...

  9. 【贪心】Codeforces Round #401 (Div. 2) D. Cloud of Hashtags

    从后向前枚举字符串,然后从左向右枚举位. 如果该串的某位比之前的串的该位小,那么将之前的那串截断. 如果该串的某位比之前的串的该位大,那么之前那串可以直接保留全长度. 具体看代码. #include& ...

随机推荐

  1. 5种做法实现table表格中的斜线表头效果

    table表格,这个东西大家肯定都不陌生,代码中我们时常都能碰到,那么给table加一个斜线的表头有时是很有必要的,但是到底该怎么实现这种效果呢? 我总结了以下几种方法: 1.最最最简单的做法 直接去 ...

  2. Vue 爬坑之路(十一)—— 基于 Nuxt.js 实现服务端渲染(SSR)

    直接使用 Vue 构建前端单页面应用,页面源码时只有简单的几行 html,这并不利于网站的 SEO,这时候就需要服务端渲染 2016 年 10 月 25 日,zeit.co 背后的团队对外发布了一个 ...

  3. JAVA_SE基础——9.基本数据类型间的转换

    前面我已经教会大家基本的数据类型进行了介绍,   然后这篇文章,我来介绍下,基本数据类型的转换. Java中有两种类型转换形式,分别是自动类型转换和强制类型转换. Step1.自动类型转换. 自动类型 ...

  4. WPF treeview扩展

    记录一下工作中遇到的问题,以便以后忘记了可以来看. 在工作中遇到一个问题,就是要实现类型如下的界面,没有使用Telerik和Dev库.本来最开始是想使用Datagrid,但不知道怎么实现treevie ...

  5. Centos7安装openvpn及客户端配置

    1.openvpn介绍 VPN直译就是虚拟专用通道,是提供给企业之间或者个人与公司之间安全数据传输的隧道,使用OpenSSL加密库中的SSLv3/TLSv1协议函数库. 目前OpenVPN能在Sola ...

  6. 新概念英语(1-125)Tea for two

    Does Susan have tea by herself?A:Can't you come in and have tea now,Peter? Not yet.B:I must water th ...

  7. springmvc4开发rest

    Spring MVC 4 RESTFul Web Services CRUD Example+RestTemplate Created on:  August 11, 2015  | Last upd ...

  8. gradle入门(1-3)使用gradle开发一个发布版本

    需求描述 1.使用Maven central仓库.2.使用Log4j写入日志.3.包含单元测试,保证正确的信息返回,单元测试必须使用JUnit编写.4.创建一个可执行的Jar文件. 我们来看一下怎样实 ...

  9. Codeforces Round #436 (Div. 2) B. Polycarp and Letters

    http://codeforces.com/contest/864/problem/B 题意: 给出一个字符串,要求找到一个集合S,使得从S中选出的所有数,在这些数的位置上的字母全部为小写且是不同的字 ...

  10. 云计算 IaaS,SaaS,PaaS的区别?一个通俗易懂的吃货文章

    来自一篇吃货文章了: ———————————————————— &lt;img src="https://pic2.zhimg.com/a55676f8e1b084a398f8cd5 ...