训练的时候对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的更多相关文章

  1. XTU 1264 - Partial Sum - [2017湘潭邀请赛E题(江苏省赛)]

    2017江苏省赛的E题,当时在场上看错了题目没做出来,现在补一下…… 题目链接:http://202.197.224.59/OnlineJudge2/index.php/Problem/read/id ...

  2. XTU 1267 - Highway - [树的直径][2017湘潭邀请赛H题(江苏省赛)]

    这道题可能有毒……总之一会儿能过一会儿不能过的,搞的我很心烦…… 依然是上次2017江苏省赛的题目,之前期末考试结束了之后有想补一下这道题,当时比较懵逼不知道怎么做……看了题解也不是很懂……就只好放弃 ...

  3. XTU 1260 - Determinant - [2017湘潭邀请赛A题(江苏省赛)][高斯消元法][快速幂和逆元]

    是2017江苏省赛的第一题,当时在场上没做出来(废话,那个时候又不懂高斯消元怎么写……而且数论也学得一塌糊涂,现在回来补了) 省赛结束之后,题解pdf就出来了,一看题解,嗯……加一行再求逆矩阵从而得到 ...

  4. XTU 1261 - Roads - [最小割][2017湘潭邀请赛B题(江苏省赛)]

    之前在网上搜了一个下午没搜到这道题的题解,然后同时又对着叉姐写的两行字题解看了一个下午: 虽然基本上已经知道了这题的思路,但愣是因为自己代码实现起来太繁复,外加不确定正确性,没敢码…… 但是一道题肝了 ...

  5. 1250 Super Fast Fourier Transform(湘潭邀请赛 暴力 思维)

    湘潭邀请赛的一题,名字叫"超级FFT"最终暴力就行,还是思维不够灵活,要吸取教训. 由于每组数据总量只有1e5这个级别,和不超过1e6,故先预处理再暴力即可. #include&l ...

  6. 湘潭邀请赛+蓝桥国赛总结暨ACM退役总结

    湘潭邀请赛已经过去三个星期,蓝桥也在上个星期结束,今天也是时候写一下总结了,这应该也是我的退役总结了~ --------------------------------湘潭邀请赛----------- ...

  7. HDU 6270 Marriage (2017 CCPC 杭州赛区 G题,生成函数 + 容斥 + 分治NTT)

    题目链接  2017 CCPC Hangzhou Problem G 题意描述很清晰. 考虑每个家庭有且仅有$k$对近亲的方案数: $C(a, k) * C(b, k) * k!$ 那么如果在第$1$ ...

  8. 湘潭邀请赛 Hamiltonian Path

    湘潭邀请赛的C题,哈密顿路径,边为有向且给定的所有边起点小于终点,怎么感觉是脑筋急转弯? 以后一定要牢记思维活跃一点,把复杂的事情尽量简单化而不是简单的事情复杂化. #include<cstdi ...

  9. 湘潭邀请赛 2018 I Longest Increasing Subsequence

    题意: 给出一个长度为n的序列,序列中包含0.定义f(i)为把所有0变成i之后的Lis长度,求∑ni=1i⋅f(i). 题解: 设不考虑0的Lis长度为L,那么对于每个f(i),值为L或L+1. 预处 ...

随机推荐

  1. IEnumerable 与 Iqueryable 的区别

    IEnumerable 和 IQueryable   共有两组 LINQ 标准查询运算符,一组在类型为 IEnumerable<T> 的对象上运行,另一组在类型为 IQueryable&l ...

  2. 160715、在web.xml中注册IntrospectorCleanupListener解决Quartz等框架可能产生的内存泄露问题

    增加方式如下:web.xml中加入  <listener>    <listener-class>org.springframework.web.util.Introspect ...

  3. 在Editplus中Dev C++配置C++的编译运行环境

    1.首先得下载安装DEV-cpp 2.打开Editplus编辑器,工具->配置自定义工具 3.具体配置 编译C:命令:D:\Dev-Cpp\MinGW64\bin\g++.exe参数:" ...

  4. javamail+postfix发送邮件

    由于在做项目时,需要用到邮箱服务.但是不想使用163,qq的,所以就自己搭一个邮箱服务器. 在搜索资料发现postfix是个不错的选择,于是就开始配置了. 这是我搜到的最全的的教程了:http://w ...

  5. 『浅入浅出』MySQL 和 InnoDB

    作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上使用非常广泛的 MySQL.PostgreSQL,但是一直以来也没有对数据库有一个非常清晰并且成体系 ...

  6. 使用ADO如何获得SQLSERVER 2K的数据库名的列表

    打开数据库连接_ConnectionPtr m_pConn;_RecordsetPtr m_pRs;m_pConn.CreateInstance(__uuidof(Connection));m_pRs ...

  7. php 正则表达式三.模式修正

    1.贪婪模式和懒惰模式, 贪婪模式:php中正则默认是贪婪模式,匹配尽可能多 的字符,比如 $pattern='/a+b/'; $subject='aaaaaaaaab,那么可能会preg_match ...

  8. win64系统丢失d3dx9d_40.dll问题

    在Win64系统中,安装了DXSDK.DX9,却一直显示如上对话框,导致程序运行不起来. 于是我在网上找到了一个d3dx9d_40.dll,覆盖到C:\Windows\System32中,但是问题依然 ...

  9. 《深入理解Linux网络技术内幕》阅读笔记 --- 路由基本概念

    一.路由的基本概念 1.一条路由就是一组参数,这些参数存储了往一个给定目的地转发流量所需的信息,而一条路由所需的最少的参数集合为:(1)目的网络,(2)出口设备,(3)下一跳网关 2.路由中的相关术语 ...

  10. python多线程锁lock/Rlock/BoundedSemaphore/Condition/Event

    import time import threading lock = threading.RLock() n = 10 def task(arg): # 加锁,此区域的代码同一时刻只能有一个线程执行 ...