【HHHOJ】NOIP2018 模拟赛(二十四) 解题报告
得分: \(100+60+100\)(挺好的,涨了一波\(Rating\))
排名: \(Rank\ 1\)
\(Rating\):\(+115\)
\(T1\):【HHHOJ13】金(点此看题面)
原题: 【洛谷2152】[SDOI2009] SuperGCD
将这道题的题意一转化,其实就是给你两个数,让你判断这两个是否互质。
而\(x\)与\(y\)互质和\(gcd(x,y)=1\)是一个意思。
所以只要求出\(gcd(x,y)\)即可。
为了避免使用高精,我们可以写\(Python\),代码如下:
def gcd(n,m):#定义函数,以供递归调用
if m==0:
return n#如果m=0,返回n
else:
return gcd(m,n%m)#否则返回gcd(m,n%m)
T=(int)(input())#读入数据组数
while T:
st=input().split()#在一行里读入两个数
n=(int)(st[0])#用n存储第一个数
m=(int)(st[1])#用m存储第二个数
if gcd(n,m)==1:
print("Yes")#如果gcd(n,m)=1,输出Yes
else:
print("No")#否则输出No
T-=1#将数据组数减1
\(T2\):【HHHOJ14】斯诺(点此看题面)
这题刚看完真的是非常懵,因此写了个大力分类讨论,交上去得了\(60\)分。
但其实看完题解后这题还是很水的。
首先,有一个基本事实:革命的区间数量\(=\)总区间数量\(\frac {n(n+1)}2-\)不革命的区间数量。
而不革命的区间其实只有三种:\(0\)的数量大于区间一半、\(1\)的数量大于区间一半、\(2\)的数量大于区间一半。
我们可以考虑把大于区间一半的数看成\(1\),小于一半的数看成\(-1\),那么我们要求的就是值\(>0\)的区间个数。
如果用\(sum_i\)表示\(\sum_{x=1}^ia_x\),则就是要求有多少个\(j\le i\)满足\(sum_i>sum_j\)。
于是我们可以开一个数组\(tot_i\)表示满足\(sum_x=i\)的\(x\)的数量。
那么我们要求的就是\(\sum_{i=-n}^{sum_x-1}tot_i\),这显然可以用前缀和+树状数组维护(虽然\(O(nlogn)\),但是由于树状数组常数巨小,所以某些奆老依然能卡过)。
不过,其实我们完全没必要这么麻烦。
可以发现,当你查询了\(tot_i\)之后,只会查询与其相邻的一位(\(tot_{i-1}\)或\(tot_{i+1}\)),因此直接\(O(1)\)更新即可。
这样一来,总复杂度就是\(O(n)\)的。
#include<bits/stdc++.h>
#define max(x,y) ((x)>(y)?(x):(y))
#define min(x,y) ((x)<(y)?(x):(y))
#define uint unsigned int
#define LL long long
#define ull unsigned long long
#define swap(x,y) (x^=y,y^=x,x^=y)
#define abs(x) ((x)<0?-(x):(x))
#define INF 1e9
#define Inc(x,y) ((x+=(y))>=MOD&&(x-=MOD))
#define ten(x) (((x)<<3)+((x)<<1))
#define N 5000000
using namespace std;
int n,a[N+5];LL ans;
class FIO
{
private:
#define Fsize 100000
#define tc() (FinNow==FinEnd&&(FinEnd=(FinNow=Fin)+fread(Fin,1,Fsize,stdin),FinNow==FinEnd)?EOF:*FinNow++)
#define pc(ch) (FoutSize<Fsize?Fout[FoutSize++]=ch:(fwrite(Fout,1,FoutSize,stdout),Fout[(FoutSize=0)++]=ch))
int f,FoutSize,OutputTop;char ch,Fin[Fsize],*FinNow,*FinEnd,Fout[Fsize],OutputStack[Fsize];
public:
FIO() {FinNow=FinEnd=Fin;}
inline void read(int &x) {x=0,f=1;while(!isdigit(ch=tc())) f=ch^'-'?1:-1;while(x=ten(x)+(ch&15),isdigit(ch=tc()));x*=f;}
inline void read_digit(int &x) {while(!isdigit(x=tc()));x&=15;}
inline void write(LL x) {if(!x) return (void)pc('0');if(x<0) pc('-'),x=-x;while(x) OutputStack[++OutputTop]=x%10+48,x/=10;while(OutputTop) pc(OutputStack[OutputTop]),--OutputTop;}
inline void end() {fwrite(Fout,1,FoutSize,stdout);}
}F;
class Class_Solver//求解
{
private:
LL tot[(N<<1)+5];
public:
inline LL Operate(int v)//操作
{
register LL sum=1;memset(tot,0,sizeof(tot));//注意清空
for(register int i=tot[N]=1,x=N;i<=n;++i)
{
if(a[i]^v) sum-=tot[x]+tot[x-1],++tot[--x],ans-=sum,sum+=tot[x];//对于a[i]不等于v的情况,将x减1
else ++tot[++x],ans-=sum,sum+=tot[x];//对于a[i]等于v的情况,将x加1
}
}
}Solver;
int main()
{
register int i;
for(F.read(n),i=1,ans=1LL*n*(n+1)>>1;i<=n;++i) F.read_digit(a[i]);//读入,初始化ans为n(n+1)/2
Solver.Operate(0),Solver.Operate(1),Solver.Operate(2);//枚举大于区间一半的数的个数
return F.write(ans),F.end(),0;
}
\(T3\):【HHHOJ15】赤(点此看题面)
做到这题真的感觉人品爆表了。
几周前学 \(WQS\)二分 时上网搜例题,第一个搜到的就是这题,没想到居然还会在模拟赛中出现!
#include<bits/stdc++.h>
#define max(x,y) ((x)>(y)?(x):(y))
#define min(x,y) ((x)<(y)?(x):(y))
#define uint unsigned int
#define LL long long
#define ull unsigned long long
#define swap(x,y) (x^=y,y^=x,x^=y)
#define abs(x) ((x)<0?-(x):(x))
#define INF 1e9
#define Inc(x,y) ((x+=(y))>=MOD&&(x-=MOD))
#define ten(x) (((x)<<3)+((x)<<1))
#define N 100000
#define eps 1e-12
using namespace std;
int n,A,B;double s1[N+5],s2[N+5];
class Class_WQS//WQS二分套WQS二分
{
private:
double C1,C2,f[N+5];int g1[N+5],g2[N+5];//用f[i]表示到第i只猫为止捕捉到的猫总数的最大期望值,并用g1[i]表示此时使用的干脆面个数,用g2[i]表示此时使用的豆干个数
inline void check()//DP转移
{
for(register int i=1;i<=n;++i)
{
f[i]=f[i-1],g1[i]=g1[i-1],g2[i]=g2[i-1];//什么都不使用
if(f[i-1]+(s1[i]-C1)-f[i]>eps) f[i]=f[i-1]+(s1[i]-C1),g1[i]=g1[i-1]+1,g2[i]=g2[i-1];//使用干脆面
if(f[i-1]+(s2[i]-C2)-f[i]>eps) f[i]=f[i-1]+(s2[i]-C2),g1[i]=g1[i-1],g2[i]=g2[i-1]+1;//使用豆干
if(f[i-1]+(s1[i]+s2[i]-C1-C2-s1[i]*s2[i])-f[i]>eps) f[i]=f[i-1]+(s1[i]+s2[i]-C1-C2-s1[i]*s2[i]),g1[i]=g1[i-1]+1,g2[i]=g2[i-1]+1;//同时使用干脆面和豆干
}
}
inline void GetRes()//第二层二分,二分C2
{
register double l=0.0,r=1.0;
for(C2=(l+r)/2;r-l>eps;C2=(l+r)/2)
{
if(check(),!(g2[n]^B)) return;//找到符合条件的C2,就可以return了
g2[n]>B?l=C2:r=C2;//如果选得物品数量偏多,将l更新为C2,否则将r更新为C2
}
}
public:
inline double GetAns()//第一层二分,二分C1
{
register double l=0.0,r=1.0;
for(C1=(l+r)/2;r-l>eps;C1=(l+r)/2)
{
if(GetRes(),!(g1[n]^A)) break;//找到符合条件的C1,就可以break了
g1[n]>A?l=C1:r=C1;//如果选得物品数量偏多,将l更新为C1,否则将r更新为C1
}
return f[n]+A*C1+B*C2;//返回答案
}
}WQS;
int main()
{
register int i;
scanf("%d%d%d",&n,&A,&B);
for(i=1;i<=n;++i) scanf("%lf",&s1[i]);
for(i=1;i<=n;++i) scanf("%lf",&s2[i]);
return printf("%.10lf\n",WQS.GetAns()),0;
}
【HHHOJ】NOIP2018 模拟赛(二十四) 解题报告的更多相关文章
- [NOIP2018模拟赛10.16]手残报告
[NOIP2018模拟赛10.16]手残报告 闲扯 炉石乱斗模式美滋滋啊,又颓到好晚... 上来T2先敲了树剖,看T1发现是个思博DP,然后没过大样例,写个暴力发现还是没过大样例!?才发现理解错题意了 ...
- EZ 2018 05 20 NOIP2018 模拟赛(十五)
这次的比赛充满着玄学的气息,玄学链接 首先讲一下为什么没有第十四场 其实今天早上9点时看到题目就叫了:原题! 没错,整套试卷都做过,我还写了题解 然后老叶就说换一套,但如果仅仅是这样就没什么 但等13 ...
- NOIp模拟赛二十八
(这是NOIp模拟赛?应该是NOI模拟赛不小心加了个p) 嗯,假装这是正经的NOIp模拟赛,从今天开始也写写题解吧(这几天被虐的惨惨) 今日情况:8+50+0=58 A题输出样例,B题正解写挂,C题不 ...
- NOIp模拟赛二十九
又是受虐的一天呢~接下来四天都要打模拟赛QAQ 今日分数:0(100)+100+0=100 A题O(读入)结论题判断结果时没return 0被subtask卡成0分,喜提fstQAQ,B题DP,C题不 ...
- EZ 2018 06 17 NOIP2018 模拟赛(十九)
这次的题目难得的水,但是由于许多哲学的原因,第二题题意表述很迷. 然后是真的猜题意了搞了. 不过这样都可以涨Rating我也是服了. Upt:链接莫名又消失了 A. 「NOIP2017模拟赛11.03 ...
- EZ 2018 06 10 NOIP2018 模拟赛(十八)
好久没写blog&&比赛题解了,最近补一下 这次还是很狗的,T3想了很久最后竟然连并查集都忘写了,然后T2map莫名爆炸. Rating爆减......链接不解释 好了我们开始看题. ...
- NOIp2018模拟赛三十六
好久没打模拟赛了...今天一样是两道国集,一道bzoj题 成绩:13+0+95=108 A题开始看错题了...导致样例都没看懂,结果xfz提醒我后我理解了一个我自认为正确的题意(事实证明我和xfz都错 ...
- [NOIP2018模拟赛10.25]瞎搞报告
闲扯 最近有点颓,都修到好晚,早上起来和吔shi一样难受 忍着困意把题面看完,发现啥也不会,又是一场写暴力的模拟赛 T1发现似乎可以DP,顺手码了个 T2像个最小瓶颈路板子,但是只做过N^2算法的.. ...
- 【HHHOJ】ZJOI2019模拟赛(十四)03.12 解题报告
点此进入比赛 得分: \(50+5+24=79\) 排名: \(Rank\ 2\) \(Rating\):\(+79\) \(T1\):[HHHOJ197]古明地(点此看题面) 基本上全部时间都用来想 ...
- EZ 2018 05 04 NOIP2018 模拟赛(十二)
这次的试卷应该是激励我们一下的,链接 然后大家的分数就都很高,然后我就210被一群秒A T2的240大佬爆踩 掉了5rating但Rank竟然发杀了 X_o_r dalao && YZ ...
随机推荐
- HELLO---MVC
前言 很荣幸有机会参加BS的项目,这个图书馆系统这个项目,需要用到ITOO框架,其中涉及到好多小框架的学习,MVC就是其中的一个学习知识点,像大家一样,刚刚接触一个新鲜的知识,心里除了恐惧还有就是茫然 ...
- Openjudge jubeeeeeat
jubeeeeeat 题目链接 总时间限制: 1000ms 内存限制: 256000kB 描述 众所周知,LZF很喜欢打一个叫Jubeat的游戏.这是个音乐游戏,游戏界面是4×4的方阵,会根据音乐 ...
- 清北刷题冲刺 10-30 p.m
少女 #include<iostream> #include<cstdio> #include<queue> #include<cstdlib> #de ...
- [Xcode 实际操作]三、视图控制器-(5)使用UINavigationController视图入栈和出栈
目录:[Swift]Xcode实际操作 本文将演示使用导航控制器的几个跳转方式 选择编辑第二个视图控制器文件 import UIKit //定义一个全局变量,用来记录当前显示区域的视图的编号 clas ...
- OSD
OSD(on-Screen Display)屏幕单式调节方式 主要功能是显示一个用户控制界面和一些系统状态信息. 简单点说:OSD技术就是在屏幕的原有图像上面叠加显示相关信息(包括文字.图片等)的技术 ...
- AT2045 Salvage Robots
传送门 这个题只要想到移动机器人和移动出口是等价的就好做了 考虑设\(f[i][j][k][t]\)为最远向左移动\(i\),向右移动\(j\),向上移动\(k\),向下移动\(t\),这个矩形内最多 ...
- POJ1027 The Same Game
题目来源:http://poj.org/problem?id=1027 题目大意: 题目说的就是现在蛮流行的手机小游戏popstar,求用贪心方法能得到多少分. 小球有三种颜色:R/G/B.横向.纵向 ...
- java程序调用.net接口服务地址的写法
参考文章:http://download.csdn.net/detail/davidiao/7424767 http://www.cnblogs.com/mq0036/p/3554002.html . ...
- 瓷砖覆盖(状压DP)
题目描述 Description 用1*2的瓷砖去铺N*M的地面,问有多少种铺法 输入描述 Input Description 第一行有两数n,m.表示地面的大小 输出描述 Output Descri ...
- HIVE获取表的大小和修改日期
### 获取表的大小 hdfs dfs -du /user/hive/warehouse/database_name.db/ > 360_du ### 获取表的修改日期 hdfs dfs -ls ...