[vijos1246]文科生的悲哀(二) 动态规划
背景
化学不及格的Matrix67无奈选择了文科。他必须硬着头皮艰难地进行着文科的学习。
描述
这学期的政治、历史和地理课本各有n章。每一科的教学必须按章节从前往后依次进行。若干章政治、若干章历史和若干章的地理内容可以合成一个教学阶段。年级计划将整个学期的内容分成若干个阶段进行教学。为了保证各科教学进度相同,年级规定每一个阶段包含的各科的章节数必须相同。一个阶段包含的章节越多,这个阶段所需要的课时也就越多。经过研究,假如某个阶段包含政史地各k章,则政治学习需要花费3^k天的课时,历史学习需要花费5^k天的课时,地理学习需要花费2^k天的课时,最后还需要4天的综合训练。一个阶段所花费的总时间是以上四项时间的和。
为了便于安排时间,学校希望每个阶段恰好需要若干周来完成。因此,划分出的每一个阶段所需要的天数都必须是7的整数倍(高三是没有星期六和星期天的)。
那么,这学期的课程最多可以划分成多少个阶段呢?你会想到,要想划分的阶段数最多,一个阶段完成一章的任务就行了(因为3^1+5^1+2^1+4=14是7的整数倍)。但问题没有这么简单。每个课本都可能有一些独立性较强的连续章节,它们具有很强的连续性,必须在一个阶段中完成。如果你已知所有不能划分在两个或两个以上的阶段中的连续章节,你还能计算出最多能安排多少个阶段吗?
格式
输入格式
第一行有两个用空格隔开的正整数n和m,分别表示各科课本的章节数和不可分割的连续章节的个数。
第二行到第m+1行,每行告诉了一个信息,该信息说明了哪一个课本的第几章到第几章必须一次性完成。同一科目给定的章节有可能重复或有重叠。
每一行信息分为两个部分。第一部分是“Politics:”、“History:”、“Geography:”三个字符串中的一个;第二部分是用“-”连接的两个数字x,y(1<=x<y<=n),表示该行第一部分所示的课本从第x章到第y章具有连续性。第二部分紧接在第一部分后面,没有任何符号分隔。
对于30%的数据,n,m<=10;
对于50%的数据,n,m<=1000;
对于100%的数据,n,m<=100 000。
输出格式
一个正整数,表示按照学校和年级的种种要求(见下)最多可以安排的阶段个数。
如果没有符合条件的安排方案,请输出-1。
注意:以下三个要求需要同时考虑。
1.每一个阶段包含的各科章数相同;
2.按时间函数计算出的各阶段所需天数必须是7的倍数;
3.给出的任一个连续章节都不能被分割开来。
样例1
样例输入1
8 3
Politics:1-2
History:5-6
Politics:1-4
样例输出1
3
限制
各个测试点1s
提示
样例说明:
最多可以安排三个阶段,具体方案如下:
第一阶段完成各科第1-6章的课程
第二阶段完成各科第7章的课程
第三阶段完成各科第8章的课程
Sample Input #2:
4 2
Geography:1-3
History:2-4
Sample Output #2:
-1
这道题做了我一个上午………………orz
一开始十分天真,注意到区间显然是可以合并之后(可以合并是因为一个阶段各科章节数一样)直接贪心了,能搞成一个阶段就搞成一个阶段……完美WA50
事实上这个数据贪心就过不了:
18 3
Politics:3-6
Geography:7-12
History:13-18
贪心结果是-1,正解是3。
接着开始找题解但是却找不到,于是开始手糊正解。先是注意到,满足条件的章节数%6必然<3,且只有在区间交接处才有答案,其他地方都为-1;
先合并区间并用pre[i]表示以i结尾的区间的起始位置。计算f[i]时只需用pre[i],pre[pre[i]],pre[pre[pre[i]]]……中满足条件的更新即可(因为f值并非递增所以不能在第一次更新后就退出)
于是这样你就得到了在vijos上用时1700+s卡过的AC代码
但这不行啊!显然是因为数据水评测机好才过的(xjoi上就T了……so sad……
继续思考,最后发现假如i与某一个j=pre[pre[……pre[i]……]]的距离%6==0,那么显然在j之前对i满足条件的k必然对j也满足条件,所以f[j]就是j及之前的最大可更新值,所以更新后就可以直接跳出啦
愉快的60+s AC~~~
评测结果及代码如下:
# | 状态 | 耗时 | 内存占用 |
---|---|---|---|
#1 | Accepted | 3ms | 4.332MiB |
#2 | Accepted | 3ms | 4.25MiB |
#3 | Accepted | 2ms | 4.25MiB |
#4 | Accepted | 2ms | 2.367MiB |
#5 | Accepted | 2ms | 2.25MiB |
#6 | Accepted | 4ms | 4.25MiB |
#7 | Accepted | 9ms | 3.195MiB |
#8 | Accepted | 10ms | 3.457MiB |
#9 | Accepted | 14ms | 3.625MiB |
#10 | Accepted | 11ms | 4.871MiB |
#include<cstdio>
#include<string>
#include<cstring>
using namespace std;
char s[];
int n,m,T[],a[],b[],c[],f[],pre[],ans,d[];
int tdigit(int l,int r){
int x=;
for(int i=l;i<=r;i++)
x=x*+s[i]-'';
return x;
}
void done(int x);
int main(){
scanf("%d%d",&n,&m);
T['P']=;T['H']=;T['G']=;
for(int i=;i<=m;i++){
scanf("%s",s); int x=,y=;
for(int i=T[s[]];i<strlen(s);i++)if(s[i]=='-'){x=tdigit(T[s[]],i-);y=tdigit(i+,strlen(s)-);break;}
a[x]++;d[y]++;
}
int p=,num=,w=;
for(int i=;i<=n;i++){
p+=a[i];p==?c[i]=:c[i]=num;p-=d[i];
if(p==)num++;
}
for(int i=;i<=n;i++)if(c[i]==||c[i]!=c[i+])pre[i]=w,w=i+;
for(int i=;i<=n;i++)if(c[i]!=&&c[i]==c[i+])f[i]=;else done(i);
printf("%d",f[n]?f[n]:-);
}
void done(int x){
int j=pre[x];
while(j){
if(f[j-]&&(x-j+)%<){
f[x]=max(f[x],f[j-]+);
if((x-j+)%==)break;
}
j=pre[j-];
}
if(j==&&f[x]==&&(x-j)%<)f[x]=;
}
[vijos1246]文科生的悲哀(二) 动态规划的更多相关文章
- [vijos1246]文科生的悲哀(二)
[vijos1246]文科生的悲哀(二) 试题描述 化学不及格的Matrix67无奈选择了文科.他必须硬着头皮艰难地进行着文科的学习. 这学期的政治.历史和地理课本各有n章.每一科的教学必须按章节从前 ...
- leetcode算法刷题(二)——动态规划(一)
上次刷了五六道题,都是关于string处理的,这次想换个知识点刷一下,然后再回头刷string的题,当做复习.. 这几天主要会选择动态规划的题目,因为以前从没刷过这方面的东西,很多东西都不是很懂..就 ...
- nyist oj 214 单调递增子序列(二) (动态规划经典)
单调递增子序列(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描写叙述 ,a2...,an}(0<n<=100000).找出单调递增最长子序列,并求出其长度 ...
- ny214 单调递增子序列(二) 动态规划
单调递增子序列(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给定一整型数列{a1,a2...,an}(0<n<=100000),找出单调递增最长子序 ...
- leetcode 总结 动态规划问题小结
动态规划 动态规划对于子问题重叠的情况特别有效,因为它将子问题的解保存在表格,当需要某个子问题的解 时,直接取值即可,从而避免重复计算. 基本思路与策略 基本思想与分治法类似,也是将带求解的问题分解为 ...
- vijos题解
Vijos题解 题库地址:https://vijos.org/p P1001 谁拿了最多奖学金 题意:按照指定要求计算奖学金,直接用if判断即可 #include<iostream> us ...
- 洛谷 P1736 创意吃鱼法 Label:dp || 前缀和
题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...
- 【JAVA、C++】LeetCode 005 Longest Palindromic Substring
Given a string S, find the longest palindromic substring in S. You may assume that the maximum lengt ...
- Fair Photography
题目大意: 给出直线上N个点的位置和颜色(0或1),求最大的区间,使得区间内0的个数大于等于1的个数且0的个数减去1的个数为偶数. 解题过程: 1.先贴个lsdsjy大牛的线段树的做法:http:// ...
随机推荐
- python爬虫-初步认识
特此声明: 以下内容来源于博主:http://blog.csdn.net/pleasecallmewhy http://cuiq ...
- R语言笔记005——计算描述性统计量
数据的分布特征: 分布的集中趋势,反应各数据向其中心值靠拢或聚集的程度(平均数,中位数,四分位数,众数) 分布的离散程度,反应各数据远离其中心值的趋势(极差,四分位差,方差,标准差,离散系数) 分布的 ...
- 如何在myEclipse中创建配置文件,比如:XXX.properties
myEclipse是没有直接生成配置文件的方法,除非去配置某些插件. 目前通用的方法是:随便新建一个文件(比如:XXX.xml),然后对该文件重命名,改成XXX.properties即可. 很简单有没 ...
- 医院Android项目总结
Eclipse ADT 配置AVD 1.layout布局:xml 如ck_report.xml <Text view ...android:id="ck"> & ...
- list!=null跟list.isEmpty()有什么区别?
这就相当与,你要喝水,前面list!=null就是判断是不是连水杯都没有,后面!list.isEmpty就是判断水杯里面没有水,连盛水的东西都没有,这个水从何而来?所以一般的判断是if(list!=n ...
- 应用程序.f/q(f了个墙)
1.20180414: 前两天,发现 CnFast不能用了,也没管它 以为过两天会好. 今天发现还是不能用,上网随便baidu下,看到个帖子:有人用加速精灵吗 现在登陆不了了 哪位大佬知道怎么回事啊[ ...
- bt种子文件是什么(包括bt文件结构)
bt种子文件是什么(包括bt文件结构) 一.总结 一句话总结:带特定格式特定信息(资源的url相关信息)的一个字符串(和json有点异曲同工之妙的感觉). 1.bt种子文件和json的区别和联系? 共 ...
- 代码题 — 剑指offer题目、新增题目
1.剪绳子 给你一根长度为n的绳子,请把绳子剪成m段 (m和n都是整数,n>1并且m>1)每段绳子的长度记为k[0],k[1],...,k[m].请问k[0]*k[1]*...*k[m] ...
- 解决:Python爬取https站点时SNIMissingWarning和InsecurePlatformWarning
今天想利用Requests库爬取糗事百科站点,写了一个请求,却报错了: 后来参考kinsomy的博客,在cmd中pip install pyopenssl ndg-httpsclient pyasn1 ...
- HYSBZ - 2038经典莫队算法题
无修改的莫队 emmm莫队的几条性质,必须是离线的,复杂度是n*sqrt(n) 就是通过预处理查询区间,然后从(l,r)转移到(ll,rr),这样的复杂度是曼哈顿距离,即abs(l-ll)+abs(r ...