2017 清北济南考前刷题Day 1 morning
期望得分:100+100+50=250
实际得分:100+60+50=210
T2 二分 估错上界、估错复杂度
T1 立方数(cubic)
Time Limit:1000ms Memory Limit:128MB
题目描述
LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数。
现在给定一个数P,LYK想要知道这个数是不是立方数。
当然你有可能随机输出一些莫名其妙的东西来骗分,因此LYK有T次询问~
输入格式(cubic.in)
第一行一个数T,表示有T组数据。
接下来T行,每行一个数P。
输出格式(cubic.out)
输出T行,对于每个数如果是立方数,输出“YES”,否则输出“NO”。
输入样例
3
8
27
28
输出样例
YES
YES
NO
数据范围
对于30%的数据p<=100。
对于60%的数据p<=10^6。
对于100%的数据p<=10^18,T<=100。
预处理所有立方数,hash
//#include<set>
#include<cstdio>
#include<iostream> using namespace std; typedef long long LL; //#define mod1 9000011
#define mod 3000017 //set<LL>s;
LL has[mod+]; int bit[]; void read(LL &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} void insert(LL x)
{
LL t=x; int len=,now=;
while(t)
{
now+=t%*bit[len++];
while(now>=mod) now-=mod;
t/=;
} while(has[now])
{
now++;
if(now==mod) now=;
}
has[now]=x;
} bool find(LL x)
{
LL t=x; int len=,now=;
while(t)
{
now+=t%*bit[len++];
while(now>=mod) now-=mod;
t/=;
}
while(has[now])
{
if(has[now]==x) return true;
now++; if(now==mod) now=;
}
return false;
} int main()
{
freopen("cubic.in","r",stdin);
freopen("cubic.out","w",stdout);
bit[]=;
for(int i=;i<=;i++) bit[i]=*bit[i-]%mod;
for(int i=;i<=;i++)// s.insert(1LL*i*i*i);
insert(1LL*i*i*i);
int T;
scanf("%d",&T);
LL x;
while(T--)
{
read(x);
//puts(s.find(x)!=s.end() ? "TES" : "NO" );
puts(find(x) ? "YES" : "NO");
}
}
T2 立方数2(cubicp)
Time Limit:1000ms Memory Limit:128MB
题目描述
LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数。
LYK还定义了一个数叫“立方差数”,若一个数可以被写作是两个立方数的差,则这个数就是“立方差数”,例如7(8-1),26(27-1),19(27-8)都是立方差数。
现在给定一个数P,LYK想要知道这个数是不是立方差数。
当然你有可能随机输出一些莫名其妙的东西,因此LYK有T次询问~
这个问题可能太难了…… 因此LYK规定P是个质数!
输入格式(cubicp.in)
第一行一个数T,表示有T组数据。
接下来T行,每行一个数P。
输出格式(cubicp.out)
输出T行,对于每个数如果是立方差数,输出“YES”,否则输出“NO”。
输入样例
5
2
3
5
7
11
输出样例
NO
NO
NO
YES
NO
数据范围
对于30%的数据p<=100。
对于60%的数据p<=10^6。
对于100%的数据p<=10^12,T<=100。
p = a^3 - b^3 = (a-b) (a^2 +ab +b^2)
因为p为素数,所以 一定是 (a-b)=1
a=b+1
后面的式子用b+1 替换 a
转化为 3*b^2 + 3*b + 1
枚举 b 即可
#include<cstdio> using namespace std; int main()
{
freopen("cubicp.in","r",stdin);
freopen("cubicp.out","w",stdout);
int T;
scanf("%d",&T);
long long p,t;
while(T--)
{
scanf("%I64d",&p);
for(int i=;;++i)
{
t= 1LL**i*i + *i + ;
if(t==p) { puts("YES"); break; }
if(t>p) { puts("NO"); break; }
}
}
}
猜数字(number)
Time Limit:1000ms Memory Limit:128MB
题目描述
LYK在玩猜数字游戏。
总共有n个互不相同的正整数,LYK每次猜一段区间的最小值。形如[li,ri]这段区间的数字的最小值一定等于xi。
我们总能构造出一种方案使得LYK满意。直到…… LYK自己猜的就是矛盾的!
例如LYK猜[1,3]的最小值是2,[1,4]的最小值是3,这显然就是矛盾的。
你需要告诉LYK,它第几次猜数字开始就已经矛盾了。
输入格式(number.in)
第一行两个数n和T,表示有n个数字,LYK猜了T次。
接下来T行,每行三个数分别表示li,ri和xi。
输出格式(number.out)
输出一个数表示第几次开始出现矛盾,如果一直没出现矛盾输出T+1。
输入样例
20 4
1 10 7
5 19 7
3 12 8
1 20 1
输出样例
3
数据范围
对于50%的数据n<=8,T<=10。
对于80%的数据n<=1000,T<=1000。
对于100%的数据1<=n,T<=1000000,1<=li<=ri<=n,1<=xi<=n(但并不保证一开始的所有数都是1~n的)。
如果一个小数的区间被一个大数的区间完全覆盖
那么就发生了矛盾
二分答案
将二分范围内的区间 按猜的数 从大到小 排序
并查集维护一个位置之后第一个没有被覆盖的位置,以此判断区间是否被完全覆盖
注意 正整数互不相同
所以若猜的同一个数 有 多个互不相交的区间,也是有矛盾的
判断这个就是 左端点的最大值>右端点的最小值
#include<cstdio>
#include<iostream>
#include<algorithm> using namespace std; int n; #define N 1000001 struct node
{
int l,r,x;
}e[N],g[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} bool cmp(node p,node q)
{
return p.x>q.x;
} int fa[N+]; int find(int i) { return fa[i]==i ? i : fa[i]=find(fa[i]); } bool check(int k)
{
for(int i=;i<=k;++i) g[i]=e[i];
sort(g+,g+k+,cmp);
int lmin=g[].l,rmin=g[].r,lmax=g[].l,rmax=g[].r;
for(int i=;i<=n+;++i) fa[i]=i;
for(int i=;i<=k;++i)
{
if(g[i].x<g[i-].x)
{
if(find(lmax)>rmin) return false;
for(int j=find(lmin);j<=rmax;++j) fa[find(j)]=find(rmax+);
lmin=lmax=g[i].l;
rmin=rmax=g[i].r;
}
else
{
lmin=min(lmin,g[i].l);
lmax=max(lmax,g[i].l);
rmin=min(rmin,g[i].r);
rmax=max(rmax,g[i].r);
if(lmax>rmin) return false;
}
}
if(find(lmax)>rmin) return false;
return true;
} int main()
{
freopen("number.in","r",stdin);
freopen("number.out","w",stdout);
int T;
read(n); read(T);
for(int i=;i<=T;++i) read(e[i].l),read(e[i].r),read(e[i].x);
int l=,r=T,mid,ans=T+;
while(l<=r)
{
mid=l+r>>;
if(!check(mid)) ans=mid,r=mid-;
else l=mid+;
}
cout<<ans;
}
#include<cstdio>
#include<iostream>
#include<algorithm> using namespace std; int n; #define N 1000001 struct node
{
int l,r,x;
}e[N],g[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} bool cmp(node p,node q)
{
return p.x>q.x;
} int fa[N+]; int find(int i) { return fa[i]==i ? i : fa[i]=find(fa[i]); } bool check(int k)
{
for(int i=;i<=k;++i) g[i]=e[i];
sort(g+,g+k+,cmp);
int lmin=g[].l,rmin=g[].r,lmax=g[].l,rmax=g[].r;
for(int i=;i<=n+;++i) fa[i]=i;
for(int i=;i<=k;++i)
{
if(g[i].x<g[i-].x)
{
if(find(lmax)>rmin) return false;
for(int j=find(lmin);j<=rmax;++j) fa[find(j)]=find(rmax+);
lmin=lmax=g[i].l;
rmin=rmax=g[i].r;
}
else
{
lmin=min(lmin,g[i].l);
lmax=max(lmax,g[i].l);
rmin=min(rmin,g[i].r);
rmax=max(rmax,g[i].r);
if(lmax>rmin) return false;
}
}
if(find(lmax)>rmin) return false;
return true;
} int main()
{
freopen("number.in","r",stdin);
freopen("number.out","w",stdout);
int T;
read(n); read(T);
for(int i=;i<=T;++i) read(e[i].l),read(e[i].r),read(e[i].x);
int l=,r=T,mid,ans=T+;
while(l<=r)
{
mid=l+r>>;
if(!check(mid)) ans=mid,r=mid-;
else l=mid+;
}
cout<<ans;
}
2017 清北济南考前刷题Day 1 morning的更多相关文章
- 2017 清北济南考前刷题Day 7 afternoon
期望得分:100+100+30=230 实际得分:100+100+30=230 1. 三向城 题目描述 三向城是一个巨大的城市,之所以叫这个名字,是因为城市中遍布着数不尽的三岔路口.(来自取名力为0的 ...
- 2017 清北济南考前刷题Day 1 afternoon
期望得分:80+30+70=180 实际得分:10+30+70=110 T1 水题(water) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK出了道水 ...
- 2017 清北济南考前刷题Day 3 morning
实际得分:100+0+0=100 T1 右上角是必败态,然后推下去 发现同行全是必胜态或全是必败态,不同行必胜必败交叉 列同行 所以n,m 只要有一个是偶数,先手必胜 #include<cstd ...
- 2017 清北济南考前刷题Day 3 afternoon
期望得分:100+40+100=240 实际得分:100+40+100=240 将每个联通块的贡献乘起来就是答案 如果一个联通块的边数>点数 ,那么无解 如果边数=点数,那么贡献是 2 如果边数 ...
- 2017 清北济南考前刷题Day 4 afternoon
期望得分:30+50+30=110 实际得分:40+0+0=40 并查集合并再次写炸... 模拟更相减损术的过程 更相减损术,差一定比被减数小,当被减数=减数时,停止 对于同一个减数来说,会被减 第1 ...
- 2017 清北济南考前刷题Day 7 morning
期望得分:100+50+20=170 实际得分:10+50+20=80 1. 纸牌 题目描述 在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数.你的邪王真眼可以看到所有牌朝上的一面和朝下的 ...
- 2017 清北济南考前刷题Day 6 afternoon
期望得分:100+100+30=230 实际得分: 正解: 枚举最高的位,这一位m是1但实际用了0 然后剩余的低位肯定是 正数就用1,负数用0 考场思路:数位DP #include<cstdio ...
- 2017 清北济南考前刷题Day 6 morning
T1 贪心 10 元先找5元 20元 先找10+5,再找3张5 #include<cstdio> using namespace std; int m5,m10,m20; int main ...
- 2017 清北济南考前刷题Day 5 afternoon
期望得分:100+100+30=230 实际得分:0+0+0=30 T1 直接模拟 #include<cstdio> #include<iostream> using name ...
- 2017 清北济南考前刷题Day 5 morning
期望得分:100+100+0=200 实际得分: 坐标的每一位不是0就是1,所以答案就是 C(n,k) #include<cstdio> #include<iostream> ...
随机推荐
- WPF四则运算《《《《《策略模式
设计思路: 因为之前没有用过WPF,听说和window窗体语法类似,就想着仿照之前的Window窗体做的,首先用三个textbox存储数据,添加一个comboBox,利用索引选择运 ...
- AttributeError: module ‘tensorflow.python.ops.nn’ has no attribute ‘leaky_relu’
#AttributeError: module 'tensorflow.python.ops.nn' has no attribute 'leaky_relu' 的原因主要是版本的问题 解决方法是更新 ...
- Visual Studio发展历程初浅调研
名称 内部版本 发布日期 支持.NET Framework版本 核心功能 竞争对手 优缺点 Visual C++ 1.0 Visual Studio的最初原型 1992 把软件开发带入了可视化开发的时 ...
- express框架实现承载静态页面的能力
我们知道nodejs本身不具有一个web容器的作用,不像tomcat或者IIS这样的服务器一样天然具有web容器承载静态动态页面的能力,如果要原生实现的话需要自己通过路由配置,比较麻烦,而expres ...
- [转帖]SQLSERVER2008R2 将于2019.7.9 结束支持服务 Windows server 2008r2 将于 2020.1.14 结束支持
来源: https://cloudblogs.microsoft.com/sqlserver/2018/07/12/sql-server-2008-end-of-support-is-the-firs ...
- css中定位功能的特性
它有四大特性,页面找不到盒子的情况 1.z-index值表示谁压着谁,数值大的压盖数值小的 2.只有定位了的元素,才有z-index.也就是说,不管相对定位,绝对定位,固定定位,都可以使用z-inde ...
- python print输出到文件
要将程序的输出送到一个文件中,需要在 print 语句后面使用 >> 指定一个文件,如下所示: principal = # 初始金额 rate = 0.05 # 利率 numyears = ...
- html实现鼠标悬停变成手型实现方式
1.采用a标签实现的方式 <a href="javascript:void()">内容</a> 2.采用CSS实现的方式 // 变手形 oElement.s ...
- matlab中 assert(any(mask(:)));
首先,matlab中any函数:检测矩阵mask中是否有非零元素,如果有,返回1,:如果没有非零元素,即所有元素都是0,那么则返回0. assert()是一个调试程序时经常使用的宏,在程序运行时它计算 ...
- 【Java并发编程】之十三:生产者—消费者模型
生产者消费者问题是线程模型中的经典问题:生产者和消费者在同一时间段内共用同一存储空间,生产者向空间里生产数据,而消费者取走数据. 这里实现如下情况的生产--消费模型: 生产者不断交替地生产两组 ...