2017 湘潭邀请赛&JSCPC G&J
训练的时候对G想了一个假算法。。也有很大可能是写错了。。
下来一看别人的G 看起来很奇妙。。
开始把所有的左括号翻成右括号,然后cost*=-1 这样在优先队列中就是最优的 然后for每一段 如果前缀和小于0就从优先队列中取右括号翻转
最后的结果一定是一个可行的括号序列
1 如果所有的原左括号都被重新反转,那么我们的选择仍然是最优,因为实际上没有在这个上面消耗
2 如果原左括号没有都被反转回去 那么我们的实际消耗也是最少的
J题一看就能想出来nmmm的想法 但是很远。。并没有想到nmm的 没想到可以nmmlogm过 就比较神奇了
画图可以发现 数字的大小其实是从右向左不断扩散的
思考nmmm的做法 对于第i个数字 枚举他是第k个a中的数字,那么就需要找到 第j个数字让它在a中做第k+1位来承接状态
但是这样状态不全 第j个数字是有限制的 它需要比第i个数字大或者小 而又有范围
因为数字的大小有规律 所以把范围也记录下来 第i个数字一定是范围的一边 于是只需要记录另一边就可以了
对于“另一边” 要么是第j个数字要么是之前传下来的 总之我们需要for一下这个范围来让他们加上当前状态
考虑区间加直接把状态加上去就可以把m变成logm了。。虽然复杂度仍然感觉不科学
G
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<vector>
#include<queue>
#include<map>
#include<algorithm>
#include<stack>
using namespace std;
#define L long long #define rep(i,l,r) for(L i = l ; i <= r ; i ++ ) const L mod = 1000000000 + 7 ; struct node {
L cost ;
L num ;
friend bool operator < (node A , node B) {
return A.cost > B.cost ;
}
}; L a[100050] ;
L b[100050] ; int main () {
L n ;
while(scanf("%lld" , &n) != EOF) {
L ans = 0 ;
rep(i,1,n) {
L l,d ; char s[20] ;
scanf("%lld%s%lld" , &l,s,&d) ;
a[i] = l ;
b[i] = d ;
if(s[0] == '(') {
ans += a[i] * b[i] ;
b[i] *= -1 ;
}
}
priority_queue<node> q ;
L sum = 0 ;
rep(i,1,n) {
node c ;
c.num = a[i] ;
c.cost = b[i] ;
q.push(c) ;
sum -= c.num ;
if(sum >= 0) continue ;
L ned = sum * (-1) ;
ned ++ ; ned /= 2 ;
sum += ned * 2;
while(ned > 0) {
node c = q.top() ; q.pop() ;
if(c.num >= ned) {
c.num -= ned ;
ans += ned * c.cost ;
q.push(c) ;
ned = 0 ;
}
else {
ned -= c.num ;
ans += c.num * c.cost ;
}
}
}
printf("%lld\n" , ans) ;
}
}
J
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<vector>
#include<queue>
#include<map>
#include<algorithm>
#include<stack>
using namespace std;
#define L long long #define rep(i,l,r) for(L i = l ; i <= r ; i ++ ) const L mod = 1000000000 + 7 ; L n , m ; L a[22] ;
L b[505] ; L dp[505][505][22] ;
L s[505][505][22] ; L lowbit(L x) {
return (x & (-x)) ;
} void add(L x,L j,L k,L val) {
while(x <= m) {
s[x][j][k] += val ;
while(s[x][j][k] < 0) s[x][j][k] += mod ;
s[x][j][k] %= mod ;
x += lowbit(x) ;
}
}
L sum(L x,L j,L k) {
L sum = 0 ;
while(x) {
sum += s[x][j][k] ;
sum %= mod ;
x -= lowbit(x) ;
}
return sum ;
}
void upda(L l,L r,L val,L j,L k) {
add(l,j,k,val) ;
add(r+1,j,k,-val) ;
} int main () {
while(cin >> n >> m) {
rep(i,1,n) cin >> a[i] ;
rep(i,1,m) cin >> b[i] ;
memset(dp, 0, sizeof(dp)) ;
memset(s, 0, sizeof(s)) ;
L ans = 0 ;
for(L i = 1 ; i <= m ; i ++ ) {
for(L j = 1 ; j <= m ; j ++ ) {
for(L k = 1 ; k <= n ; k ++ ) {
if(k == 1) {
L bord ;
if(a[1] == 0) bord = m ;
else bord = 1 ;
if (bord != j) continue ;
dp[i][bord][1] = 1 ;
if (k == n){
ans += dp[i][j][k];
ans %= mod ;
}
} else {
dp[i][j][k] = sum(b[i], j, k);
if (k == n){
ans += dp[i][j][k];
ans %= mod ;
}
}
}
}
for(L j = 1 ; j <= m ; j ++ ) {
for(L k = 1 ; k <= n ; k ++ ) {
if(k == 1) {
L bord ;
if(a[1] == 0) bord = m ;
else bord = 1 ;
if (bord != j) continue ;
L x = min(bord,b[i]) ;
L y = max(bord,b[i]) ;
if(a[2] == 0) {
upda(x,y,1,y,2) ;
} else {
upda(x,y,1,x,2) ;
}
} else {
L x = min(j, b[i]);
L y = max(j, b[i]);
if (dp[i][j][k] == 0) continue;
if (a[k + 1] == 0) {
upda(x, y, dp[i][j][k], y, k + 1);
} else {
upda(x, y, dp[i][j][k], x, k + 1);
}
}
}
} }
printf("%lld\n" , ans) ;
}
}
J线段树会T。。。
2017 湘潭邀请赛&JSCPC G&J的更多相关文章
- XTU 1264 - Partial Sum - [2017湘潭邀请赛E题(江苏省赛)]
2017江苏省赛的E题,当时在场上看错了题目没做出来,现在补一下…… 题目链接:http://202.197.224.59/OnlineJudge2/index.php/Problem/read/id ...
- XTU 1267 - Highway - [树的直径][2017湘潭邀请赛H题(江苏省赛)]
这道题可能有毒……总之一会儿能过一会儿不能过的,搞的我很心烦…… 依然是上次2017江苏省赛的题目,之前期末考试结束了之后有想补一下这道题,当时比较懵逼不知道怎么做……看了题解也不是很懂……就只好放弃 ...
- XTU 1260 - Determinant - [2017湘潭邀请赛A题(江苏省赛)][高斯消元法][快速幂和逆元]
是2017江苏省赛的第一题,当时在场上没做出来(废话,那个时候又不懂高斯消元怎么写……而且数论也学得一塌糊涂,现在回来补了) 省赛结束之后,题解pdf就出来了,一看题解,嗯……加一行再求逆矩阵从而得到 ...
- XTU 1261 - Roads - [最小割][2017湘潭邀请赛B题(江苏省赛)]
之前在网上搜了一个下午没搜到这道题的题解,然后同时又对着叉姐写的两行字题解看了一个下午: 虽然基本上已经知道了这题的思路,但愣是因为自己代码实现起来太繁复,外加不确定正确性,没敢码…… 但是一道题肝了 ...
- 1250 Super Fast Fourier Transform(湘潭邀请赛 暴力 思维)
湘潭邀请赛的一题,名字叫"超级FFT"最终暴力就行,还是思维不够灵活,要吸取教训. 由于每组数据总量只有1e5这个级别,和不超过1e6,故先预处理再暴力即可. #include&l ...
- 湘潭邀请赛+蓝桥国赛总结暨ACM退役总结
湘潭邀请赛已经过去三个星期,蓝桥也在上个星期结束,今天也是时候写一下总结了,这应该也是我的退役总结了~ --------------------------------湘潭邀请赛----------- ...
- HDU 6270 Marriage (2017 CCPC 杭州赛区 G题,生成函数 + 容斥 + 分治NTT)
题目链接 2017 CCPC Hangzhou Problem G 题意描述很清晰. 考虑每个家庭有且仅有$k$对近亲的方案数: $C(a, k) * C(b, k) * k!$ 那么如果在第$1$ ...
- 湘潭邀请赛 Hamiltonian Path
湘潭邀请赛的C题,哈密顿路径,边为有向且给定的所有边起点小于终点,怎么感觉是脑筋急转弯? 以后一定要牢记思维活跃一点,把复杂的事情尽量简单化而不是简单的事情复杂化. #include<cstdi ...
- 湘潭邀请赛 2018 I Longest Increasing Subsequence
题意: 给出一个长度为n的序列,序列中包含0.定义f(i)为把所有0变成i之后的Lis长度,求∑ni=1i⋅f(i). 题解: 设不考虑0的Lis长度为L,那么对于每个f(i),值为L或L+1. 预处 ...
随机推荐
- IEnumerable 与 Iqueryable 的区别
IEnumerable 和 IQueryable 共有两组 LINQ 标准查询运算符,一组在类型为 IEnumerable<T> 的对象上运行,另一组在类型为 IQueryable&l ...
- 160715、在web.xml中注册IntrospectorCleanupListener解决Quartz等框架可能产生的内存泄露问题
增加方式如下:web.xml中加入 <listener> <listener-class>org.springframework.web.util.Introspect ...
- 在Editplus中Dev C++配置C++的编译运行环境
1.首先得下载安装DEV-cpp 2.打开Editplus编辑器,工具->配置自定义工具 3.具体配置 编译C:命令:D:\Dev-Cpp\MinGW64\bin\g++.exe参数:" ...
- javamail+postfix发送邮件
由于在做项目时,需要用到邮箱服务.但是不想使用163,qq的,所以就自己搭一个邮箱服务器. 在搜索资料发现postfix是个不错的选择,于是就开始配置了. 这是我搜到的最全的的教程了:http://w ...
- 『浅入浅出』MySQL 和 InnoDB
作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上使用非常广泛的 MySQL.PostgreSQL,但是一直以来也没有对数据库有一个非常清晰并且成体系 ...
- 使用ADO如何获得SQLSERVER 2K的数据库名的列表
打开数据库连接_ConnectionPtr m_pConn;_RecordsetPtr m_pRs;m_pConn.CreateInstance(__uuidof(Connection));m_pRs ...
- php 正则表达式三.模式修正
1.贪婪模式和懒惰模式, 贪婪模式:php中正则默认是贪婪模式,匹配尽可能多 的字符,比如 $pattern='/a+b/'; $subject='aaaaaaaaab,那么可能会preg_match ...
- win64系统丢失d3dx9d_40.dll问题
在Win64系统中,安装了DXSDK.DX9,却一直显示如上对话框,导致程序运行不起来. 于是我在网上找到了一个d3dx9d_40.dll,覆盖到C:\Windows\System32中,但是问题依然 ...
- 《深入理解Linux网络技术内幕》阅读笔记 --- 路由基本概念
一.路由的基本概念 1.一条路由就是一组参数,这些参数存储了往一个给定目的地转发流量所需的信息,而一条路由所需的最少的参数集合为:(1)目的网络,(2)出口设备,(3)下一跳网关 2.路由中的相关术语 ...
- python多线程锁lock/Rlock/BoundedSemaphore/Condition/Event
import time import threading lock = threading.RLock() n = 10 def task(arg): # 加锁,此区域的代码同一时刻只能有一个线程执行 ...