【题目链接】:http://codeforces.com/contest/777/problem/D

【题意】

让你通过删除字符串的末尾字符的方式;

使得所给的字符串以字典序升序排序;

不能交换字符串之间的位置;

【题解】

/*
要求字符串的字典序升序排;
不能交换字符串的位置;
那就使得
s[i]<=s[i+1]对i∈[1..n-1]都成立就好;
(这里的<=指的是字典序的小于等于);
从最后一个字符串开始;
逆序处理字符串1..n-1;
对比字符串s[i]和s[i+1]的所有字符;
对比的时候len = min(s[i].size(),s[i+1].size());
找到第一个字符不一样的位置pos;
如果找到了这样一个pos;
记录它
if (s[i][pos]<s[i+1][pos])
则这个字符串出现在这里是合法的;
符合s[i]<=s[i+1]
if (s[i][pos]>s[i+1][pos])
则把s[i]从pos开始全部删掉;
然后处理下一个; 当然,如果pos没有找到的话,就比较s[i].size()和s[i+1].size();
如果s[i].size()<=s[i+1].size();则合法
否则从s[i].size()+1开始把s[i]从s[i].size()+1一直到结束全部删掉
(可以不用真的删掉吧。写一个to[n];
表示每个字符串输出的时候要一直输出到哪个地方.
*/

【完整代码】

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <string>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%lld",&x) typedef pair<int, int> pii;
typedef pair<LL, LL> pll; const int dx[9] = { 0,1,-1,0,0,-1,-1,1,1 };
const int dy[9] = { 0,0,0,-1,1,-1,1,-1,1 };
const double pi = acos(-1.0);
const int N = 5e5 + 100; string s[N];
int n;
int to[N];
bool bo[N]; int main()
{
//读入优化??
//freopen("D:\\rush.txt", "r", stdin);
rei(n);
rep1(i, 1, n)
cin >> s[i];
int len = s[n].size();
len--;
to[n] = len;
rep2(i, n - 1, 1)
{
int len = min(to[i + 1], int(s[i].size())-1);
int pos = -1;
rep1(j,1,len)
if (s[i][j] != s[i + 1][j])
{
pos = j;
break;
}
if (pos != -1)
{
if (s[i][pos] < s[i + 1][pos])
{
to[i] = int(s[i].size())-1;
continue;
}
if (s[i][pos] > s[i + 1][pos])
{
to[i] = pos - 1;
continue;
}
}
if (int(s[i].size()) <= to[i + 1])
{
to[i] = int(s[i].size())-1;
continue;
}
to[i] = to[i + 1];
}
rep1(i, 1, n)
{
putchar('#');
rep1(j, 1, to[i])
putchar(s[i][j]);
puts("");
}
return 0;
}

【codeforces 777D】Cloud of Hashtags的更多相关文章

  1. Codeforces 777D:Cloud of Hashtags(水题)

    http://codeforces.com/problemset/problem/777/D 题意:给出n道字符串,删除最少的字符使得s[i] <= s[i+1]. 思路:感觉比C水好多啊,大概 ...

  2. Codeforces 777D:Cloud of Hashtags(暴力,水题)

    Vasya is an administrator of a public page of organization "Mouse and keyboard" and his ev ...

  3. 【codeforces 415D】Mashmokh and ACM(普通dp)

    [codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...

  4. 【codeforces 707E】Garlands

    [题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...

  5. 【codeforces 707C】Pythagorean Triples

    [题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...

  6. 【codeforces 709D】Recover the String

    [题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...

  7. 【codeforces 709B】Checkpoints

    [题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...

  8. 【codeforces 709C】Letters Cyclic Shift

    [题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...

  9. 【Codeforces 429D】 Tricky Function

    [题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...

随机推荐

  1. [D3] Build a Line Chart with D3 v4

    Line charts are often used to plot temporal data, like a stock price over time. In this lesson we’ll ...

  2. amazeui学习笔记--css(布局相关1)--网格Grid

    amazeui学习笔记--css(布局相关1)--网格Grid 一.总结 基本使用 1.div+class布局:amaze里面采取的就是div+class的布局方式  <div class=&q ...

  3. C++组合数(combination)的实现

    实现: (nm) 既需要计算组合的总数 (32)=3: 也需要分别获得每一种组合的情形,用于穷举搜索: 1, 2; 1, 3; 2, 3 1. 递归实现 // picked + toPick == m ...

  4. 微信支付v2开发(8) 维权通知

    本文介绍微信支付中如何获得维权通知. 一.维权通知URL 在 微信支付开发(1) 微信支付URL配置 已提到,维权通知URL为 http://www.doucube.com/wxpay/rights. ...

  5. jquery中empty()和remove()的区别

    empty 顾名思义,清空方法,但是与删除又有点不一样,因为它只移除了 指定元素中的所有子节点. remove与empty一样,都是移除元素的方法,但是remove会将元素自身移除,同时也会移除元素内 ...

  6. Android onLoadFinished与onLoaderReset

    onLoadFinished 这个方法是在前面已创建的加载器已经完成其加载过程后被调用,这个方法保证会在应用到加载器上的数据被释放之前被调用.在此方法中,你必须删除所有对旧数据的使用(因为它将很快会被 ...

  7. zabbix自定义监控mysql

    创建用户: use mysql; grant all privileges on *.* to 'zabbix'@'%' identified by 'zabbixpasswd'; grant all ...

  8. php 如何写一个自己项目的安装程序

    版权声明:此篇文章只是用作笔记,如果版权冲突,请邮件通知一下(15201155501@163.com) https://blog.csdn.net/shenpengchao/article/detai ...

  9. IDC报告:从IaaS到PaaS,阿里云主导云计算市场

    11月7日,著名国际研究机构IDC发布了2017年上半年中国公共云PaaS市场调研结果,阿里云以27%的份额保持压倒性领先,是第二名的近三倍.结合IDC上一份IaaS市场的报告(阿里云第一,占比47. ...

  10. Go语言实战_自己定义OrderedMap

    一. 自己定义OrderedMap 在Go语言中.字典类型的元素值的迭代顺序是不确定的.想要实现有固定顺序的Map就须要让自己定义的 OrderedMap 实现 sort.Interface 接口类型 ...