EZ 2018 04 01 ZJOI2018模拟赛04.01
现在开始填以前的坑
这次老叶强制我们打一下这次省选题,然后我已经做好了掉Rating到死的准备
然后考完……莫名涨了 Orz
由于很多东西我都不会,所以详细请看:dalao的题解
T1 我TM的竟然直接A了???
考试的时候过了1个多小时完全没有思路,然后跟着yekehe&CJJ出去吃饭了,然后回来联想到了一道数科竞赛班类似的题目(那时候还没退),然后进行了一下推理然后搞出了答案。
我们来看一下:
要求 1/x+1/y=1/n! 的x,y对数
设z=n!
由原式易得x,y>z,便设x=z+k
原式变为:1/(z+k)+1/y=1/z
移项 1/y=1/z-1/(z+k)
通分 1/y=(z+k)/z(z+k)-z/z(z+k)
减一下得 1/y=k/z(z+k)
两边同取倒数得 y=z(z+k)/k=(z2+zk)/k=z2/k+z
由于x,y,z为正整数,所以y必为z^2的因数
问题便转化为求z^2的因数个数
通过因数个数的公式:
其中a1、a2、a3…ak是p1、p2、p3,…pk的指数。(p为质数)
对于n≤106的范围,我们只要把sqrt(n)的范围内,即1000以内的质数打表打出来(不打也行),然后找出(n!)2所有质数的次数,乘起来即可
CODE
#include<cstdio>
#include<algorithm>
using namespace std;
const int P=168,prime[P]={2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997},mod=1e9+7,N=1e6;
int n,c[P],t[N],h[N],k=0,p=0;
long long ans=1;
int main()
{
register int i,j;
scanf("%d",&n);
for (i=2;i<=n;++i)
{
int x=i;
for (j=0;j<P;++j)
{
while (x%prime[j]==0) ++c[j],x/=prime[j];
if (x==1) break;
}
if (x>997) t[++k]=x;
}
sort(t+1,t+k+1);
for (i=1;i<=k;++i)
if (t[i]!=t[i-1]) h[++p]++; else h[p]++;
for (i=0;i<P;++i)
ans=(ans*(c[i]*2+1))%mod;
for (i=1;i<=p;++i)
ans=(ans*(h[i]*2+1))%mod;
printf("%lld",ans);
}
T2
弃坑,二分+后缀数组
留着以后学会了后缀数组的姿势再来补
T3
爆搜30pts
当然可以稍微想一下,显然只选2个区间是最优的,因为取一个集合中所有区间一定没有只取最左和最右两个区间优。 对于那些有包含关系的区间,更新一下答案,只留下最大的区间就可以了。
O(n^2)枚举就有60pts
对于标算,要利用决策单调性来艹(这个我当然不会)
而且当时max忘写long long了,60炸成30
60ptsCODE
#include<cstdio>
#include<algorithm>
using namespace std;
const int N=100005;
struct data
{
int x,y;
}a[N];
long long ans=0;
int n;
inline char tc(void)
{
static char fl[100000],*A=fl,*B=fl;
return A==B&&(B=(A=fl)+fread(fl,1,100000,stdin),A==B)?EOF:*A++;
}
inline void read(int &x)
{
x=0; char ch=tc();
while (ch<'0'||ch>'9') ch=tc();
while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=tc();
}
inline void swap(data &a,data &b)
{
data t=a; a=b; b=t;
}
inline long long max(long long a,long long b)
{
return a>b?a:b;
}
inline void check(int x,int y)
{
if (a[x].x>a[y].x) swap(x,y);
if (a[x].y>=a[y].x) ans=max(ans,(long long)(a[y].y-a[x].x+1)*(a[x].y-a[y].x+1));
}
int main()
{
//freopen("C.in","r",stdin); freopen("C_.out","w",stdout);
register int i,j;
read(n);
for (i=1;i<=n;++i)
read(a[i].x),++a[i].x,read(a[i].y);
for (i=1;i<=n;++i)
for (j=1;j<=n;++j)
{
if (i==j) continue;
check(i,j);
}
printf("%lld",ans);
return 0;
}
EZ 2018 04 01 ZJOI2018模拟赛04.01的更多相关文章
- EZ 2018 06 17 NOIP2018 模拟赛(十九)
这次的题目难得的水,但是由于许多哲学的原因,第二题题意表述很迷. 然后是真的猜题意了搞了. 不过这样都可以涨Rating我也是服了. Upt:链接莫名又消失了 A. 「NOIP2017模拟赛11.03 ...
- EZ 2018 06 10 NOIP2018 模拟赛(十八)
好久没写blog&&比赛题解了,最近补一下 这次还是很狗的,T3想了很久最后竟然连并查集都忘写了,然后T2map莫名爆炸. Rating爆减......链接不解释 好了我们开始看题. ...
- EZ 2018 03 30 NOIP2018 模拟赛(六)
链接:http://211.140.156.254:2333/contest/67 转眼间上次加回来的Rating又掉完了. 这次不知为何特别水,T1想了一段时间没想出来弃了,导致后面心态炸了. T2 ...
- EZ 2018 03 09 NOIP2018 模拟赛(三)
最近挺久没写比赛类的blog了 链接:http://211.140.156.254:2333/contest/59 这次的题目主要考验的是爆搜+打表的能力 其实如果你上来就把所有题目都看过一次就可以知 ...
- EZ 2018 06 24 NOIP2018 模拟赛(二十)
很久之前写的一套题了,由于今天的时间太多了,所以记起来就写掉算了. 这一场尽管T2写炸了,但也莫名Rank4涨了Rating.不过还是自己太菜. A. 环游世界 首先我们先排个序,想一下如果不用走回来 ...
- EZ 2018 07 06 NOIP模拟赛
又是慈溪那边给的题目,这次终于没有像上次那样尴尬了, T1拿到了较高的暴力分,T2没写炸,然后T3写了一个优雅的暴力就203pts,Rank3了. 听说其它学校的分数普遍100+,那我们学校还不是强到 ...
- EZ 2018 06 02 NOIP2018 模拟赛(十七)
这次的比赛是真心比较狗,我TM的写了30min的树剖ZZ地直接memset超时了 话说我既然想到差分就应该去写差分的啊! 好了不过这次Rank还挺高的,终于要打进前10了当然是假的了. 好了下面开始讲 ...
- EZ 2018 05 26 NOIP2018 模拟赛(十六)
这次难道就是传说中的标准分大赛?而且这次比赛的链接不翼而飞了 一堆人153pts然后就有Rank4?看来这个Rank4不值钱了,才涨了50+的Rating. 不过还好最后5min的时候想出了T1正解, ...
- EZ 2018 05 20 NOIP2018 模拟赛(十五)
这次的比赛充满着玄学的气息,玄学链接 首先讲一下为什么没有第十四场 其实今天早上9点时看到题目就叫了:原题! 没错,整套试卷都做过,我还写了题解 然后老叶就说换一套,但如果仅仅是这样就没什么 但等13 ...
随机推荐
- Vue -- webpack 项目自动打包压缩成zip文件
这段时间用 Vue2.0 开发项目,每次打包都会用到 npm run build 命令,但是每次部署时给后端发包都要手动zip压缩,这样一两次还行,但遇到项目板块测试和临时加急功能测试的时候,一天可能 ...
- 关于kernel-devel、kernel-header和kernel src的区别
A kernel-header package would contain 'header files' needed by some applications which would be buil ...
- 学习vue.js的正确姿势(转载)
最近饶有兴致的又把最新版 Vue.js 的源码学习了一下,觉得真心不错,个人觉得 Vue.js 的代码非常之优雅而且精辟,作者本身可能无 (bu) 意 (xie) 提及这些.那么,就让我来吧:) 程序 ...
- apk安装提示:Failure [INSTALL_FAILED_DUPLICATE_PERMISSION perm=XXX]
近日,楼主在同一台手机上,同时安装同一个游戏的不同渠道包,add install后,提示:Failure [INSTALL_FAILED_DUPLICATE_PERMISSION perm=andro ...
- Oracle EBS INV 更新状态
使用API改变现有物料状态,改成如下:On-Hand, Subinventory, Locator, Lot & Serial.参数使用如下:H, O, S, Z, L.对应如下: 'H' - ...
- If TransactionScope will close database connections
问 Do TransactionScope work with closed database connections? using (var transaction = new Transactio ...
- sysbench 多线程异步io模拟mysql测试的脚本
用于测试的脚本: for size in 100 do cd /mnt/stec sysbench --test=fileio --file-num=1 --file-total-size=${siz ...
- 通过ajax GET方式查询数据,Django序列化objects
点击“查找2”按钮,通过ajax GET方式进行查询数据,这样页面不需要整体刷新,之后清空tbody数据,将查询结果重新附加到tbody 前端html: <div class="box ...
- DELL MD3200i存储控制器解锁方法
DELL MD3200i存储控制器解锁方法 现有一台DELL MD3200i存储,因种种原因导致控制器被锁定,这里是刚出厂的一台存储,出现这个问题让我们都很困惑,只能怀疑DELL公司的问题. 这台存储 ...
- python基础学习1
一.python第一个程序 print("hello world") 二.变量的命名规则 1. 字母数字下划线组成 2. 不能以数字开头,不能含有特殊字符和空格 3. 不能以保留字 ...