前言

赛时:好难啊,什么都不会

刚结束:原来如此

现在:为什么我这么菜


洛谷 5657 格雷码

代码(找规律)

#include <cstdio>
using namespace std;
typedef unsigned long long ull;
ull k,now=1; char c[101]; int n;
int main(){
scanf("%d%llu",&n,&k);
for (int i=1;i<=n;++i){
if (((k/now)&3)==1||((k/now)&3)==2) c[n-i+1]=49;
else c[n-i+1]=48;
now<<=1;
}
for (int i=1;i<=n;++i) putchar(c[i]);
return 0;
}

洛谷 5658 括号树

题目


分析

考虑在树上动态维护一个装入左括号的栈,

一个显然的性质就是以\(i\)结尾的合法括号串个数等于前一个左括号的前驱的个数+1

但是赛时只想到这个性质没有想到用栈维护QWQ


代码

#include <cstdio>
#include <cctype>
#define rr register
using namespace std;
const int N=500011; long long ans,s[N];
struct node{int y,next;}e[N];
int col[N],top,st[N],cnt[N],ls[N],n,k=1,fat[N];
inline signed iut(){
rr int ans=0; rr char c=getchar();
while (!isdigit(c)) c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans;
}
inline void dfs(int x){
rr int tmp=0;
if (col[x]){
if (top){
tmp=st[top];
cnt[x]=cnt[fat[tmp]]+1;
--top;
}
}else st[++top]=x;
s[x]=s[fat[x]]+cnt[x];
for (rr int i=ls[x];i;i=e[i].next)
dfs(e[i].y);
if (tmp) st[++top]=tmp;
else if (top) --top;
}
signed main(){
n=iut();
for (rr int i=1;i<=n;++i){
rr char c=getchar();
while (c!='('&&c!=')') c=getchar();
col[i]=c==')';
}
for (rr int i=2;i<=n;++i){
rr int x=iut(); fat[i]=x;
e[++k]=(node){i,ls[x]},ls[x]=i;
}
dfs(1);
for (rr int i=1;i<=n;++i) ans^=1ll*s[i]*i;
return !printf("%lld",ans);
}

洛谷 5659 树上的数

待更


洛谷 5664 Emiya 家今天的饭

待更


洛谷 5665 划分

题目


分析

单调队列裸题,考场没想到qwq

不过这题比较恶心的是要用高精度

根据\((a+b)^2>a^2+b^2\)可以知道要尽量多分段

设\(dp[i]\)表示前\(i\)个位置所能取到的最大的\(j\)

那么\(dp[i]=\max\{j\}[s_i-s_j\geq s_j-s_{dp[j]}]\)

由于\(s\)是单调递增的,那么可以用单调队列维护


代码

#include <cstdio>
#include <cctype>
#define rr register
#define calc(x) ((s[x]<<1)-s[dp[x]])
using namespace std;
const int aod=1073741823,N=40000011;
typedef unsigned uit;
typedef long double ld;
typedef long long lll; lll s[N];
int n,typ,q[N],dp[N],head,tail;
const lll mod=100000000000000000ll;
inline signed iut(){
rr int ans=0; rr char c=getchar();
while (!isdigit(c)) c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans;
}
inline lll mul(lll a,lll b){
a%=mod,b%=mod;
rr lll c=(ld)a*b/mod,ans=a*b-c*mod;
ans=ans<0?ans+mod:(ans>=mod?ans-mod:ans);
return ans;
}
signed main(){
n=iut(),typ=iut();
if (!typ){
for (rr int i=1;i<=n;++i) s[i]=s[i-1]+iut();
}else {
rr uit X=iut(),Y=iut(),Z=iut(),a1=iut(),a2=iut(),a3;
iut(),s[1]=a1,s[2]=a2; rr int TAIL=iut(),L=iut(),R=iut();
for (rr int i=1;i<3;++i){
a3=s[i]%(R-L+1)+L,s[i]=s[i-1]+a3;
if (TAIL==i&&TAIL<n) TAIL=iut(),L=iut(),R=iut();
}
for (rr int i=3;i<=n;++i){
a3=(a2*X+a1*Y+Z)&aod,a1=a2,a2=a3;
a3=a3%(R-L+1)+L,s[i]=s[i-1]+a3;
if (TAIL==i&&TAIL<n) TAIL=iut(),L=iut(),R=iut();
}
}
for (rr int i=1;i<=n;++i){
while (head<tail&&s[i]>=calc(q[head+1])) ++head;
dp[i]=q[head];
while (head<tail&&calc(q[tail])>=calc(i)) --tail;
q[++tail]=i;
}
rr lll ans[2]={0,0},t[2];
for (rr int i=n;i;i=dp[i]){
rr lll t1=s[i]-s[dp[i]];
t[1]=mul(t1,t1),t[0]=(ld)t1*t1/mod;
ans[0]+=t[0],ans[1]+=t[1];
if (ans[1]>=mod) ++ans[0],ans[1]-=mod;
}
if (ans[0]) printf("%lld%017lld",ans[0],ans[1]);
else printf("%lld",ans[1]);
return 0;
}

洛谷 5666 树的重心

待更


后记

wtcl,什么都不会

CSP2019-S2总结的更多相关文章

  1. CSP2019 S2滚粗记

    最好分数:100+20+10+64+64+55 最坏分数:100+20+10+64+36+55 咕咕数据分数:100+25+10+64+60+55 CCF官方: 100+35+10+64+36+55= ...

  2. CSP2019总结

    CSP2019总结 前言 赛前停课集训了两个星期,自认为已经准备充分了,结果... 不知道有没有写挂分,即使一分没挂,满打满算也只有400出头,还是太菜了. Day0 晚上复习了一会,打了会游戏就睡了 ...

  3. s2 devMode cmdshell

    s2 devMode cmdshell   仅支持批量验证,命令执行 链接:http://pan.baidu.com/s/1sl7tgRV 密码:wud8 也可以通过outscan一键获取,之后导入t ...

  4. 电源相关知识—S0、S1(POS)、S2、S3(STR)、 S4、S5、睡眠、休眠、待机

    转 http://blog.sina.com.cn/s/blog_52f28dde0100l3ci.html APM https://en.wikipedia.org/wiki/Advanced_Po ...

  5. 判断s2是否能够被通过s1做循环移位(rotate)得到的字符串是否包含

    问题:给定两个字符串s1和s2,要求判断s2是否能够被通过s1做循环移位(rotate)得到的字符串包含.例如,S1=AABCD和s2=CDAA,返回true:给定s1=ABCD和s2=ACBD,返回 ...

  6. S2 易买网总结

    易买网项目总结 --指导老师:原玉明 不知不觉,又到了S2结业的时间了,S1的项目KTV项目还历历在目.一路走来,感觉时间过的好快,我们离就业也越来越近... 展示: 1.主页面(首页) 01.商品分 ...

  7. 445. Add Two Numbers II ——while s1 or s2 or carry 题目再简单也要些测试用例

    You are given two linked lists representing two non-negative numbers. The most significant digit com ...

  8. 写一个函数,实现两个字符串的比较。即实现strcmp函数,s1=s2时返回0,s1!=s2时返回二者第一个不同字符的ASCII值。

    #include<stdio.h> #include<stdlib.h> int main(){ setvbuf(stdout,NULL,_IONBF,); ],s2[]; i ...

  9. ACPI电源管理中的S0 S1 S2 S3 S4 S5

    电源选项中S0,S1,S2,S3,S4,S5的含义以 ACPI 的规格来说吧!ACPI(Advanced Configuration and Power Interface),即高级配置与电源接口.这 ...

  10. S2第一本书内测

    <深入.NET平台和C#编程>内部测试题-笔试试卷 一 选择题 1) 以下关于序列化和反序列化的描述错误的是( C). a) 序列化是将对象的状态存储到特定存储介质中的过程 b) 二进制格 ...

随机推荐

  1. KPTP 汇报模板

    1.什么是KPTP 它是由4个单词:Keep.Problem.Try.Plan的首字母组成的. K:keep,今天做了哪些工作: P:problem,遇到了哪些问题: T:try,计划尝试如何解决这些 ...

  2. 红胖子(红模仿)的博文大全:开发技术集合大版本更新v4.0.0

    <红胖子(红模仿)的博文大全:开发技术集合(包含Qt实用技术.树莓派.三维.OpenCV.OpenGL.ffmpeg.OSG.单片机.软硬结合等等)持续更新中...>大版本更新,更新后版本 ...

  3. 【LeetCode哈希表】前k个高频词,利用哈希表+vector进行排序操作

    前k个高频词 https://leetcode.cn/problems/top-k-frequent-words/ 给定一个单词列表 words 和一个整数 k ,返回前 k 个出现次数最多的单词. ...

  4. 矩池云上 git clone --recursive 出错,怎么解决

    遇到问题 有时候安装包教程里 git clone 的时候会出现以下错误: git clone --recursive https://github.91chi.fun/https://github.c ...

  5. 老生常谈的iOS- weak原理,你真的懂得还是为了应付面试

    前言 weak对于iOS开发来说只要解决一些对象相互引用的时候,避免出现强强引用,对象不能被释放,出现内存泄露的问题. weak 关键字的作用域弱引用,所引用对象的计数器不会加一,并在引用对象被释放的 ...

  6. 【Azure Redis 缓存】遇见Azure Redis不能创建成功的问题:至少一个资源部署操作失败,因为 Microsoft.Cache 资源提供程序未注册。

    问题描述 在中国区微软云上创建Redis失败.收到的错误消息为: { "code": "DeploymentFailed", "message&quo ...

  7. 【Azure 应用服务】App Service for Container中配置与ACR(Azure Container Registry)的RABC权限

    问题描述 在使用App Service for container时,在从ACR(Azure Container Registry)中获取应用的镜像时,需要使用对应的权限.默认情况为在ACR中启用Ad ...

  8. 【Azure 应用服务】如何关掉App Service/Function App的FTP部署, 使之变成FTPS

    问题描述 如何关掉App Service/Function App的FTP部署, 使之变成FTPS方式呢? 问题解答 在应用服务/函数应用的配置下选择右边的常规设置,然后修改FTP状态为"仅 ...

  9. ExoPlayer播放流程解析

    ExoPlayer的播放解析流程如下(以音频为例): 注意: 1.LoadControl.shouldContinueLoading控制是否继续加载. 2.调用setPlayWhenReady(tru ...

  10. STL-unordered_hashtable模拟实现

    #pragma once #include<vector> #include<string> #include<iostream> using std::cout; ...