NSOJ10050 Newspaper Headline
题意:给你一个<10^4的S串和<10^6的T串,通过将S串重复k次,然后将其中一些多余的字母删掉可以获得T串,问k最小是多少,没有的话输出1.
思路:对于每个T串里的字母,我们从左到右扫,由于我们一定要找到对应的字母,于是我们必然是尽可能早的在S串里找到这个字母,然后再从匹配的串的位置开始继续往后找T串的下一个字母。所以贪心的思路就是我们总是尽量在S串的前面匹配到T的对应字母。
譬如样例 S:abcd T:dabc, 首先我们肯定要匹配d,所以我们一开始将指针移到S的d的位置,然后发现往后不能再匹配了,然后又回到串首,发现可以匹配d的下一个a,然后从a开始又能匹配下一个b,类似的我们就可以匹配完全部的字母了,然后得出最少的次数。
实现的话其实也不困难,我们可以建一个类似自动机的东西,S串的每个字母相当于一个状态,然后对每个字母我们推算出其下一个最近的a,b,c,d...z在哪个位置。实现的方法很简单,开一个vector<int> alpha[26],alpha[i]存的是第i个字符的所有下标,所以每次找的时候就一个upper_bound就可以了。然后就在这个自动机上走就是了,每次走到NULL结点的时候cnt++. 如果当前在根结点仍然不能往下匹配到下一个T串的点的时候就说明是-1。
题目还是挺简单的,不知道为什么当时没什么人过,赛后也没什么人做。。- -0
#pragma warning(disable:4996)
#include<iostream>
#include<cstring>
#include<vector>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<string>
#define ll long long
#define maxn 10500
using namespace std; char S[maxn];
char T[maxn*100]; struct Node
{
Node *go[26];
void init() { memset(go, 0, sizeof(go)); }
}pool[maxn];
Node *root;
vector<int> alpha[26];
vector<int>::iterator it;
int main()
{
while (~scanf("%s%s", S, T))
{
int lens = strlen(S);
pool[0].init();
root = &pool[0];
for (int i = 0; i < 26; i++) {
alpha[i].clear();
alpha[i].push_back(0);
}
for (int i = 0; i < lens; i++){
pool[i + 1].init();
alpha[S[i] - 'a'].push_back(i + 1);
}
for (int i = 0; i <= lens; i++){
for (int j = 0; j < 26; j++){
it = upper_bound(alpha[j].begin(), alpha[j].end(), i);
if (it == alpha[j].end()) continue;
else pool[i].go[j] = &pool[*it];
}
}
int cnt = 0;
int lent = strlen(T);
Node *p = NULL; bool flag = true;
int i = 0;
while(i<lent){
if (p == NULL) cnt++, p = root;
if (p == root&&p->go[T[i] - 'a'] == NULL) {
flag = false; break;
}
p = p->go[T[i] - 'a'];
if (p != NULL) i++;
}
if (flag) printf("%d\n", cnt);
else printf("-1\n");
}
return 0;
}
NSOJ10050 Newspaper Headline的更多相关文章
- CodeForces 91A Newspaper Headline
题目链接:CodeForces - 91A Newspaper Headline 官方题解: In this problem letters from s1 should be taken gree ...
- AtCoder Beginner Contest 058 ABCD题
A - ι⊥l Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Three poles st ...
- Newspaper Headline_set(upper_bound)
Description A newspaper is published in Walrusland. Its heading is s1, it consists of lowercase Lati ...
- week0713.5 newspaper 安装问题
然后爆红说nltk==2.0.5 太老了 所以我们 把包下载下来将requirements文件中nltk==2.0.5改成3.3.0 然后 将包打包 然后安装这个包就OK 下载newpaper wge ...
- 解决pymysql.err.InternalError: (1366, "Incorrect string value: '\\xF0\\x9F\\x8C\\xB8' for column 'headline' at row 1")
解决pymysql.err.InternalError: (1366, "Incorrect string value: '\\xF0\\x9F\\x8C\\xB8' for column ...
- TPO-15 C1 The campus newspaper's reporter position
TPO-15 C1 The campus newspaper's reporter position 第 1 段 1.Listen to a conversation between a Studen ...
- python3使用newspaper快速抓取任何新闻文章正文
newspaper用于爬取各式各样的新闻网站 1,安装newspaper pip install newspaper3k 2,直接上代码 from newspaper import Article u ...
- [翻译角]Headline English: A Captain Should Be Pitch Perfect at a Multitude of Skills (ESLPOD Blog)
以下转自www.eslpod.com,翻译为本人添加.其余版权均归原网站所有. ESLPOD是一个英语学习网站,我最初知道这个网站,是因为“奶爸”<把你的英语用起来>(电子版3元)一书的推 ...
- 爬虫时安装的newspaper 新闻包
Newspaper3k: Article scraping & curation 首先在命令行安装 newspaper pip install Newspaper3k 然后导入包进行写代码 f ...
随机推荐
- 《gpg文件加密的使用》RHEL6
甲端: 首先是要生成一对密钥: 提示是否要生成2048个字节的密钥对: 下面都是生成密钥对时的步骤: 按“o”键开始生成密钥对: 提示要我给密钥对加个密码: 输入2次 之后密钥对的字符需要我按键盘 ...
- Fedora 20下安装官方JDK替换OpenJDK并配置环境变量
Fedora 20自带OpenJDK,所以如果安装官方的JDK的话要先删除OpenJDK,步骤如下: 1:rpm -qa|grep jdk 查看当前的jdk情况. 2:yum -y remove ja ...
- 在linux下查看内核版本、gcc版本、操作系统多少位等参数
1. 查看linux版本 cat /etc/issue Ubuntu 11.04 \n \l 2. 查看内核版本 1)cat /proc/version Linux version 2.6.38-13 ...
- javascript对象与实例
var person=new Object(); var person2={}; 一切都是对象 person是Object的实例, 也是对象. 第二个person2也是如此,只不过它是采用字面量的方式 ...
- 获取SilverLight.Web项目中路径Uri
方法一: //获取指定要呈现的xaml内容的包活xaml文件Uri var strFullUrl = Application.Current.Host.Source.AbsoluteUri; if ( ...
- .Net 将一个DataTable分解成多个DataTable
这两天遇到一个问题,我们所接触 的一个系统在导出数据到Excel的时候,产生了内存溢出的错误.原因在于数据过大,它导出是将所有数据存放在一个DataSet的一个表中,再将这个数 据集放入session ...
- hadoop架构
HADOOP中可以分为两个大的模块,存储模块和计算模块.HDFS作为存储模块,JobTracker,TaskTracker构成计算模块. 1.HADOOP的文件是以HDFS格式存储的 HDFS ...
- python学习第四天第一部分
1.字典的特性:无序.去重.查询速度快.比list占用内存多. 2.字典查询速度快的原因:因为他是哈希类型的. 3.什么是(hash)哈希? hash把任意长度的二进制映射为较短的固定长度的二进制,这 ...
- Jquery LigerUI框架学习(二)之Tree于Tab标签实现iframe功能
LigerUI框架Tree于Tab标签动态使用,当点击Tree后动态创建Tab标签,和通常用的iframe框架功能类似 Tree中的关键代码 //Tree初始化 $("#tree1" ...
- .NET开发Windows Service程序 - Topshelf
在实际项目开发过程中,会经常写一些类似定时检查,应用监控的应用.这类应用在windows平台通常都会写成window service程序. 在百度上搜索一下'c#开发windows service', ...