国庆 Day1
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.最佳团体
玄学题目
复杂度未知,假装是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.起床困难综合症
一道思维题,二进制运算至于位有关,并没有与整体有关
所以就可以打一个表,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的更多相关文章
- 正睿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- ...
- 清北国庆day1 (脑)残
(留坑) /* 不知道为什要找的循环节TM这么长 */ #include<cstdio> #include<cstdlib> #include<cstring> u ...
- 学大伟业 2017 国庆 Day1
期望得分:100+100+20=220 实际得分:100+100+20=220 (好久没有期望==实际了 ,~\(≧▽≦)/~) 对于 a........a 如果 第1个a 后面出现的第1个b~z 是 ...
- 国庆集训 Day1 T2 生成图 DP
国庆集训 Day1 T2 生成图 现在要生成一张\(n\)个点的有向图.要求满足: 1.若有 a->b的边,则有 b->a 的边 2.若有 a->b 的边和 b->c 的边,则 ...
- 牛客2018国庆集训 DAY1 D Love Live!(01字典树+启发式合并)
牛客2018国庆集训 DAY1 D Love Live!(01字典树+启发式合并) 题意:给你一颗树,要求找出简单路径上最大权值为1~n每个边权对应的最大异或和 题解: 根据异或的性质我们可以得到 \ ...
- 湖南国庆模拟赛day1 分组
题目大意:给你一个n个数的数列s,要对这些数进行分组,当有任意两个数在一种方案在一起而在另一种方案中不在一起算是两种不同的方案,一个组的"不和谐程度"为组内数的极差,如果只有一个人 ...
- 2017北京国庆刷题Day1 afternoon
期望得分:100+100+100=300 实际得分:100+100+100=300 T1 一道图论好题(graph) Time Limit:1000ms Memory Limit:128MB 题目 ...
- 牛客国庆训练,CCPC Camp DAY1 J 倍增,括号匹配
https://www.nowcoder.com/acm/contest/201#question 题意:中文不翻译了 解法的个人理解: 对于一个合法的区间$[L,R]$ 1.显然其左括号的匹配位置都 ...
- 牛客国庆集训派对Day1.B.Attack on Titan(思路 最短路Dijkstra)
题目链接 \(Description\) 给定\(n,m,C\)及大小为\((n+1)(m+1)\)的矩阵\(c[i][j]\).平面上有\((n+1)(m+1)\)个点,从\((0,0)\)编号到\ ...
随机推荐
- web漏洞原理 (需要每周更新此篇文章)
SQL注入攻击简介 结构化查询语言SQL是用来和关系数据库进行交互的文本语言.它允许用户对数据进行有效的管理,包含了对数据的查询.操作.定义和控制等几个方面,例如向数据库写入.插入数据,从数据库读取数 ...
- Python递归算法入门
递归是一种算法,它在编程里面有着广泛的应用: 1. 递归必须满足哪两个基本条件? 一.函数调用自身 二.设置了正确的返回条件 2. 思考一下,按照递归的特性,在编程中有没有不得不使用递归的情况? 答: ...
- 使用es6总结笔记
1. let.const 和 block 作用域 在ES6以前,var关键字声明变量.无论声明在何处,都会被视为声明在函数的最顶部(不在函数内即在全局作用域的最顶部). let 关键词声明的变量不具备 ...
- python numpy数据相减
numpy数据相减,a和b两者shape要一样,然后是对应的位置相减.要不然,a的shape可以是(1,m),注意m要等于b的列数. import numpy as np a = [ [0, 1, 2 ...
- Java进阶知识点:并发容器背后的设计理念
一.背景 容器是Java编程中使用频率很高的组件,但Java默认提供的基本容器(ArrayList,HashMap等)均不是线程安全的.当容器和多线程并发编程相遇时,程序员又该何去何从呢? 通常有两种 ...
- php 安全方面面试题
1 MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化? a. 设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率.b. 选择合适的表字段数据类型和存储 ...
- 一道java笔试题
输入一串用空格隔开的数字串,对于数字串的奇数位按升序排序,偶数位按降序排序. 示例输入: 4 6 2 3 6 7 8 1 处理过程: 奇数位:4 2 6 8 升序排序结果: 2 4 6 8 偶数位:6 ...
- Linux 150命令之 文件和目录操作命令 ls
文件和目录操作命令 ls 查看文件和目录查看显示详信息 ls 工具的参数 ls -l 查看文件详细信息 ls -h 查看文件的大小 ls -ld 只查看目录信息 ls –F 给不同文件加上不同标记 l ...
- NTP错误总结
Ntp错误总结 解决ntp的错误 no server suitable for synchronization found 当用ntpdate -d 来查询时会发现导致 no server suita ...
- JS中通过数组的方式操作字符串 数组是个好东西 ....
题目:使用JS将 var str="what are you nong sha lei",通过您的方法转换为"What Are You Nong Sha Lei" ...