[CSP-S模拟测试53]题解
A.u
只涉及到区间修改可以考虑差分,然而如果每一行都差分复杂度还是过高。我们发现差分标记也是连续的(一行横着的一行斜着的),所以可以维护两个 差分的差分,扫两遍统计即可。
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
typedef long long ll;
const int N=2005;
int read()
{
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
int n,q;
ll dif1[N][N],dif2[N][N];
int main()
{
//freopen("dt.in","r",stdin);
//freopen("my.out","w",stdout);
n=read();q=read();
while(q--)
{
int r=read(),c=read(),l=read(),val=read();
dif1[r][c]+=val;dif1[r+l][c]-=val;
dif2[r][c+1]-=val;dif2[r+l][c+l+1]+=val;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
dif2[i][j]+=dif2[i-1][j-1],dif1[i][j]+=dif1[i-1][j];
ll ans=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
dif1[i][j]+=dif1[i][j-1]+dif2[i][j],ans^=dif1[i][j];
}
cout<<ans<<endl;
return 0;
}
B.v
二进制状压一下当前场上剩余球的状态,记搜即可。记忆化状态需要手写Hash表,直接map会T飞。
另外,在本题中形如00110和0110的状态是不同的,为了区分我们可以给Hash表多加一个长度的参数,每次查询或插入时先调到相应的长度再操作。
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
const int H=2e7+5;
struct hash_map
{
int head[19260820],nxt[H],to[H],tot;
short L[H],len;
double val[H];
double &operator [] (int key)
{
int x=1LL*key*len%19260817;
for(int i=head[x];i;i=nxt[i])
if(to[i]==key&&L[i]==len)return val[i];
nxt[++tot]=head[x];
head[x]=tot;
to[tot]=key;
L[tot]=len;
return val[tot]=-1;
}
}h;
const int N=35;
int n,K;
char s[N];
int erase(int st,int pos)
{
return st>>pos<<pos-1|st&(1<<pos-1)-1;
}
double dfs(int pos,int st)
{
if(n-K==pos)return 0;
h.len=pos;int sst=st;
if(h[st]>=0)return h[st];
h[st]=0;
int rez[N];
for(int i=1;i<=pos;i++,sst>>=1)
rez[i]=sst&1;
for(int i=1;i<=(pos>>1);i++)
{
int j=pos-i+1;
int s1=erase(st,j),s2=erase(st,i);
double res1=dfs(pos-1,s1)+rez[j],res2=dfs(pos-1,s2)+rez[i];
h.len=pos;h[st]+=2.0/pos*max(res1,res2);
}
if(pos&1)
{
int i=(pos>>1)+1,s1=erase(st,pos-i+1);
double res=dfs(pos-1,s1)+rez[i];
h.len=pos;h[st]+=1.0/pos*res;
}
return h[st];
} int main()
{
scanf("%d%d%s",&n,&K,s+1);
int now=0;
for(int i=1;i<=n;i++)
{
now<<=1;
if(s[i]=='W')now|=1;
}
printf("%.7lf\n",dfs(n,now));
return 0;
}
C.w
神仙dp。如果把反转一条路径看作增加这样的一条路径,那么最终增加的路径数就等于奇点个数/2。
#include<cstdio>
#include<iostream>
#include<cstring>
#define pa pair<int,int>
using namespace std;
int read()
{
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
const int N=1e5+5,inf=0x3f3f3f3f;
int n;
int to[N<<1],head[N],nxt[N<<1],w[N<<1],tot;
pa dp[N][2];
pa pls(pa x,pa y)
{
return make_pair(x.first+y.first,x.second+y.second);
}
void add(int x,int y,int z)
{
to[++tot]=y;
nxt[tot]=head[x];
head[x]=tot;
w[tot]=z;
}
void dfs(int x,int f,int e)
{
pa a=make_pair(0,0),b=make_pair(inf,inf),c,d;
for(int i=head[x];i;i=nxt[i])
{
int y=to[i];
if(y==f)continue;
dfs(y,x,w[i]);
c=min(pls(a,dp[y][0]),pls(b,dp[y][1]));
d=min(pls(a,dp[y][1]),pls(b,dp[y][0]));
a=c;b=d;
}
if(e==1)dp[x][0]=make_pair(inf,inf);
else dp[x][0]=min(a,make_pair(b.first+1,b.second));
if(e==0)dp[x][1]=make_pair(inf,inf);
else dp[x][1]=min(make_pair(a.first+1,a.second+1),make_pair(b.first,b.second+1));
} int main()
{
n=read();
for(int i=1;i<n;i++)
{
int x=read(),y=read(),col=read(),aim=read(),z;
if(aim==2)z=aim;
else z=col^aim;
add(x,y,z);add(y,x,z);
}
dfs(1,1,0);
cout<<(dp[1][0].first>>1)<<' '<<dp[1][0].second<<endl;
return 0;
}
[CSP-S模拟测试53]题解的更多相关文章
- [考试反思]0927csp-s模拟测试53:沦陷
很喜欢Yu-shi说过的一句话 在OI里,菜即是原罪 对啊. 都会.谁信呢? 没有分数,你说话算什么呢? 你就是菜,你就是不对,没有别的道理. 最没有用的,莫过于改题大神,这就是菜的借口. 但是其实这 ...
- CSP-S 模拟测试94题解
T1 yuuustu: 可以对两边取对数,然后就转化为两个double的比较,时间复杂度$O(n)$ 然后我就用神奇0.4骗分水过 #include<bits/stdc++.h> usin ...
- CSP-S模拟测试 88 题解
T1 queue: 考场写出dp柿子后觉得很斜率优化,然后因为理解错了题觉得斜率优化完全不可做,只打了暴力. 实际上他是可以乱序的,所以直接sort,正确性比较显然,贪心可证,然后就是个sb斜率优化d ...
- CSP-S 模拟测试92 题解
话说我怎么觉得我没咕多长时间啊,怎么就又落了20多场题解啊 T1 array: 根据题意不难列出二元一次方程,于是可以用exgcd求解,然而还有一个限制条件就是$abs(x)+abs(y)$最小,这好 ...
- CSP-S 模拟测试57题解
人生第一次A,B层一块考rank2,虽然说分差没几分,但还是值得纪念. 题解: T1 天空龙: 大神题,因为我从不写快读也没有写考场注释的习惯,所以不会做,全hzoi就kx会做,kx真大神级人物. T ...
- CSP-S 模拟测试 51 题解
考试过程: 惯例先看一遍三道题,T1 一开始反应要求割点,但是这是有向图,肯定不能求割点,康了一下数据范围,有40%是树的,还不错,决定待会在打. 看T2 字符串题,完了我字符串最弱了,肯定只能打暴力 ...
- CSP-S 模拟测试 45 题解
由于咕掉的题解太多了,所以只能趁改完不动题的时间,来补补坑qwq,还是太弱了. 考试过程: 到新机房的第一次考试,貌似海星? 第一题一开始就觉得是个贪心,但以为所有小怪兽都要打完,所以想复杂了,但后来 ...
- [CSP-S模拟测试97]题解
A.小盆友的游戏 感觉题解解释的很牵强啊……还是打表找规律比较靠谱 对于每个人,它构造了一个期望函数$f(x)$,设它的跟班个数为$cnt[x]$,那么令$f(x)=2^{cnt[x]}-1$(??鬼 ...
- [CSP-S模拟测试96]题解
以后不能再借没改完题的理由不写题解了…… A.求和 求$\sum \sum i+j-1$ 柿子就不化了吧……这年头pj都不考这么弱智的公式化简了…… 坑点1:模数不定,可能没有2的逆元,那么只要先把乘 ...
随机推荐
- 10.14.1-linux设置时间等
设置时间[root@wen /]# date -s "20171014 15:42:00"2017年 10月 14日 星期六 15:42:00 CST 格式化时间[root@wen ...
- python3下tomorow模块报语法错误def async(n, base_type, timeout=None): ^ SyntaxError: invalid syntax
python3 pip 安装tomorrow模块,调用时候会报错:def async(n, base_type, timeout=None): ^ SyntaxError: invalid synta ...
- LUOGU P4088 [USACO18FEB]Slingshot(线段树)
传送门 解题思路 推了推式子发现是个二维数点,想了想似乎排序加线段树难写,就写了个树套树,结果写完看见空间才\(128M\)..各种奇技淫巧卡空间还是\(MLE\)到天上.后来只好乖乖的写排序+线段树 ...
- CTF | bugku | 速度要快
检查源码时发现有 <!-- OK ,now you have to post the margin what you find --> 检查响应头发现有 flag: 6LeR55qE6L+ ...
- (转)Groovy简介
转:https://www.w3cschool.cn/groovy/ Groovy的官方网站是http://www.groovy-lang.org/ Groovy是一种基于JVM(Java虚拟机)的敏 ...
- webpack 中vue文件使用scss需要注意的地方
需要使用npm添加node_sass和sass_loader 并且在配置文件中添加规则: { test: /\.scss$/, use: ["style-loader", &quo ...
- 面试题:Nginx 是如何实现高并发?常见的优化手段有哪些?
面试题: Nginx 是如何实现并发的?为什么 Nginx 不使用多线程?Nginx常见的优化手段有哪些?502错误可能原因有哪些? 面试官心理分析 主要是看应聘人员的对NGINX的基本原理是否熟悉, ...
- Django-自定义用户模型
Django最方便的一点,是自带用户系统,但有些情况下,不符合项目需求, 原因1.我们有时候需要自定义一些字段,或者删除Django自带字段,2.我们有时候需要定义哪些字段是必填的,登陆时的用户名是哪 ...
- java 异常处理try+catch
在整个异常处理机制中,异常在系统中进行传递,传递到程序员认为合适的位置,就捕获到该异常,然后进行逻辑处理,使得项目不会因为出现异常而崩溃.为了捕获异常并对异常进行处理,使用的捕获异常以及处理的语法格式 ...
- leetcode-7-整数翻转
问题: package com.example.demo; public class Test7 { /** * 整数翻转 123,-123,120等数字 * 思路: * 1.获取原始数字的%10的余 ...