This is a 玄学 exam

A.年轮蛋糕

最小的最大,二分首选

断环为链,check(x),x为答案,然后将每个大于x的子区间记录下来

如果有大于3个的话,那么x就可以是答案

那么·,在优化下来,二分里套个下二分,查长度右端点

时间复杂度:O(log(10^13)^3*n)

但是AC了

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
inline int read()
{
int f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return f*ans;
}
long long n,a[],s[],l,r,mid,maxn,inf=<<-;
long long cx(long long ll,long long rr,long long sc)
{
long long da=inf;
long long ls=ll,rs=rr,mid;
while(ls<=rs)
{
mid=(ls+rs)/;
if(s[mid]>=sc) da=min(da,mid),rs=mid-;
else ls=mid+;
}
return da;
}
bool check(long long xx)
{
for(long long i=;i<=n;i++)
{
long long qv=s[i-],ll=i,rr=i+n-,res=;
while(ll<=rr)
{
if(res==)
{
if(s[rr]-qv>=xx) return ;
else break;
}
long long as=cx(ll,rr,qv+xx);
if(as==inf)
{
if(res>=) return ;
else break;
}
qv=s[as];
ll=as+;
res++;
if(res==)
{
if(s[rr]-qv>=xx) return ;
else break;
}
if(res>=) return ;
}
}
return ;
}
int main()
{
n=read();
for(long long i=;i<=n;i++) a[i]=read(),a[i+n]=a[i],r+=a[i];
for(long long i=;i<=*n;i++) s[i]=s[i-]+a[i];
while(l<=r)
{
mid=(l+r)/;
if(check(mid)) maxn=max(maxn,mid),l=mid+;
else r=mid-;
}
printf("%lld",maxn);
}

B.最佳团体

link

玄学题目

复杂度未知,假装是A了吧

一看到一个和/一个和,分数规划的经典题

又想到若x可以作为答案的话,x之前也可以作为答案

所以可以二分

然后这个问题可以转化成在树上做背包即可

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
inline int read()
{
int f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return f*ans;
}
double eps=1e-;
struct node{
int u,v,nex;
}x[];
int cnt,n,head[],s[],t[];
double val[],dp[][];
double l,r,mid,maxn;
void add(int u,int v)
{
x[cnt].u=u,x[cnt].v=v,x[cnt].nex=head[u],head[u]=cnt++;
}
int m,size[],deep[];
void dfs(int f,int fath)
{
deep[f]=deep[fath]+;
size[f]=;
for(int i=head[f];i!=-;i=x[i].nex)
{
dfs(x[i].v,f);
size[f]+=size[x[i].v];
}
}
void dp_tree(int xx)
{
dp[xx][]=;int k=min(m,size[xx]);
for(int i=head[xx];i!=-;i=x[i].nex)
{
int v=x[i].v;
dp_tree(v);
for(int t=k;t>=;t--)
for(int j=min(t,size[v]);j>=;j--) dp[xx][t]=max(dp[xx][t],dp[xx][t-j]+dp[v][j]);
}
if(xx!=)
for(int t=k;t>=;t--) dp[xx][t]=dp[xx][t-]+val[xx];
}
bool check(double xx)
{
bool flag=false;
memset(dp,0xcf,sizeof(dp));
for(int i=;i<=n;i++)
val[i]=double(s[i]-xx*t[i]);
dp_tree();
return dp[][m]>=;
}
int main()
{
memset(head,-,sizeof(head));
m=read(),n=read();
for(int i=;i<=n;i++)
{
t[i]=read(),s[i]=read();
r+=double(s[i]);
int v=read();
add(v,i);
}
dfs(,);
l=,r*=;
while(l<=r)
{
double mid=(l+r)/;
if(check(mid)) l=mid+eps,maxn=max(maxn,mid);
else r=mid-eps;
}
printf("%.3lf",maxn);
}

C.起床困难综合症

link

一道思维题,二进制运算至于位有关,并没有与整体有关

所以就可以打一个表,0000000,1111111,位数都为30为(int的精度),然后与输入数据处理一下

看一下0可以转换成什么,1可以转换成什么

然后瞎搞一下即可

#include<iostream>
#include<cstdio>
#include<cstring>
#include<climits>
#include<algorithm>
using namespace std;
inline int read()
{
int f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return f*ans;
}
int n,m,l,r=INT_MAX,data,sry;
char str[];
int main()
{
n=read(),m=read();
for(int i=;i<=n;i++)
{
scanf("%s",str+);
if(str[]=='A') {int s=read();l&=s,r&=s;}
else if(str[]=='O') {int s=read();l|=s,r|=s;}
else
{int s=read();l^=s,r^=s;}
}
for(int i=;i>=;i--)
{
if(l&(<<i)) data|=(<<i);
else if(sry+(<<i)<=m)
if(r&(<<i)) data|=(<<i),sry+=(<<i);
}
cout<<data;
}
/*
3 10
AND 5
OR 6
XOR 7
*/

国庆 Day1的更多相关文章

  1. 正睿OI国庆day1

    正睿OI国庆day1 T1 \[ S_n=1*S_{n-1}+1*F_{n-1}+1*F_{n-2}+1*f_{n-1}+1*f_{n-2} \] \[ F_{n}=0*S_{n-1}+1*F_{n- ...

  2. 清北国庆day1 (脑)残

    (留坑) /* 不知道为什要找的循环节TM这么长 */ #include<cstdio> #include<cstdlib> #include<cstring> u ...

  3. 学大伟业 2017 国庆 Day1

    期望得分:100+100+20=220 实际得分:100+100+20=220 (好久没有期望==实际了 ,~\(≧▽≦)/~) 对于 a........a 如果 第1个a 后面出现的第1个b~z 是 ...

  4. 国庆集训 Day1 T2 生成图 DP

    国庆集训 Day1 T2 生成图 现在要生成一张\(n\)个点的有向图.要求满足: 1.若有 a->b的边,则有 b->a 的边 2.若有 a->b 的边和 b->c 的边,则 ...

  5. 牛客2018国庆集训 DAY1 D Love Live!(01字典树+启发式合并)

    牛客2018国庆集训 DAY1 D Love Live!(01字典树+启发式合并) 题意:给你一颗树,要求找出简单路径上最大权值为1~n每个边权对应的最大异或和 题解: 根据异或的性质我们可以得到 \ ...

  6. 湖南国庆模拟赛day1 分组

    题目大意:给你一个n个数的数列s,要对这些数进行分组,当有任意两个数在一种方案在一起而在另一种方案中不在一起算是两种不同的方案,一个组的"不和谐程度"为组内数的极差,如果只有一个人 ...

  7. 2017北京国庆刷题Day1 afternoon

    期望得分:100+100+100=300 实际得分:100+100+100=300 T1 一道图论好题(graph) Time Limit:1000ms   Memory Limit:128MB 题目 ...

  8. 牛客国庆训练,CCPC Camp DAY1 J 倍增,括号匹配

    https://www.nowcoder.com/acm/contest/201#question 题意:中文不翻译了 解法的个人理解: 对于一个合法的区间$[L,R]$ 1.显然其左括号的匹配位置都 ...

  9. 牛客国庆集训派对Day1.B.Attack on Titan(思路 最短路Dijkstra)

    题目链接 \(Description\) 给定\(n,m,C\)及大小为\((n+1)(m+1)\)的矩阵\(c[i][j]\).平面上有\((n+1)(m+1)\)个点,从\((0,0)\)编号到\ ...

随机推荐

  1. Qt-QML-C++交互实现文件IO系统-后继-具体文件IO的实现

    在上一篇文章中,我大致将这个QML中的文件IO类搭出了大致的框架,那么,今天抽时间写了一点文件的读写,这里我使用的文件流来读写文件. 文件结构如图 在QML中调用这个类了,就见简单的读取了一个JSON ...

  2. WEB安全基础之sql注入基础

    1.基础sql语句 注释 单行注释# %23--+ --加空格多行注释/**/ SELECT(VERSION()) SELECT(USER()) SELECT(database()) 查数据库 SEL ...

  3. Java 递归 反射 正则表达式

    一 递归 1. 就是函数自身调用自身 (就是在栈内存中不断的加载同一个函数) 2. 什么时候用递归呢? 当一个功能被重复使用 而每一次使用该功能时的参数不确定 都由上次的功能元素结果来确定 简单说: ...

  4. Dos命令以及相关文件的访问

    1.转到相关目录 有时候想从当前目录转到D盘,用此目录cd d:是没有用的, 最好用cd /d d:是可以的 2.查看目录文件 dir 3.往服务器上传文件文件 通过文件浏览器上传文件,只适用于Win ...

  5. 关于javascript的一个小问题,请问有人看出啥问题吗?

    最近学习javascript,有一个问题挺奇怪的,先贴出代码: function binarySearch(){ var arr = [0,1,2,3]; var res = actbinarySea ...

  6. 【Random】-随机数字-jmeter

    参数化 Random 参数化,存储结果的变量名,名字写了,就可以给其它请求使用

  7. 《Effective C++》读书笔记 被你忽略的关于构造析构赋值

    如果程序员没有定义,那么编译器会默认隐式为你创建一个copy构造函数,一个copy赋值操作符,一个析构函数.另外如果你没有声明任何构造函数,编译器会为你声明一个default构造函数. 但是只有当这些 ...

  8. psp1111

    1 本周psp 2.本周进度条 3.本周累积进度图 代码累积折线图 博文字数累积折线图 4.本周PSP饼状图

  9. JavaScript初探系列之基本概念

    JavaScript的核心语言特性在ECMA-262中是以名为ECMAScript(ECMA, EuropeanComputer Manufacturers Association )的伪语言的形式来 ...

  10. android 出现Make sure the Cursor is initialized correctly before accessing data from it

    Make sure the Cursor is initialized correctly before accessing data from it 详细错误是:java.lang.IllegalS ...