bzoj 3837 (随机过题法了解一下)
3837: [Pa2013]Filary
Time Limit: 60 Sec Memory Limit: 256 MB
Submit: 395 Solved: 74
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
7 4 10 8 7 1
Sample Output
HINT
听说大家都喜欢随机过题法,于是我切一道(正解是)随机的题目涨涨姿势。
#include<bits/stdc++.h>
#define clr(x) memset(x,0,sizeof(x))
#define clr_1(x) memset(x,-1,sizeof(x))
#define INF 0x3f3f3f3f
#define LL long long
#define pb push_back
#define mod 1000000007
#define ls(i) (i<<1)
#define rs(i) (i<<1|1)
#define mp make_pair
#define fi first
#define se second
using namespace std;
const int N=1e7+;
const int M=1e5+;
int inf[N],prime[N],pre[N],g[N],num[N];
int tot;
int gcd(int a,int b)
{
int c;
while(b)
c=a%b,a=b,b=c;
return a;
}
void init()
{
tot=;
int n=;
for(int i=;i<=n;i++)
{
if(!inf[i])
prime[++tot]=i,pre[i]=tot;
for(int j=;j<=tot && prime[j]*i<=n;j++)
{
inf[prime[j]*i]=;
pre[prime[j]*i]=j;
if(i%prime[j]==) break;
}
}
return ;
}
int a[M],b[M];
int main()
{
init();
int n,m,k;
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",a+i);
int p=log10(n)+;
srand(time());
m=k=;
while(p--)
{ int pos=rand()%n+;
int tmp=;
int minm=,mink=;
for(int i=;i<=n;i++)
{
b[i]=abs(a[i]-a[pos]);
if(!b[i])
tmp++;
}
for(int i=;i<=n;i++)
{
int t=b[i];
while(t && t!=)
{
int temp=pre[t];
num[temp]++,g[temp]=gcd(g[temp],b[i]);
if(mink<num[temp]) mink=num[temp],minm=g[temp];
else if(mink==num[temp]) minm=max(g[temp],minm);
while(t%prime[temp]==) t/=prime[temp];
}
}
if(mink+tmp>k) k=mink+tmp,m=minm;
else if(mink+tmp==k) m=max(m,minm);
for(int i=;i<=n;i++)
{
int t=b[i];
while(t && t!=)
{
int temp=pre[t];
num[temp]=,g[temp]=;
while(t%prime[temp]==) t/=prime[temp];
}
}
}
printf("%d %d\n",k,m);
return ;
}
bzoj 3837 (随机过题法了解一下)的更多相关文章
- ppt VBA 实现随机抽题
目录 目标/最终效果 关于VBA VBA简单示例 检查环境 步骤 VBA实现随机抽题 todo challenge 目标/最终效果 目标是制作一个ppt,实现随机抽题,具体描述: 第一页幻灯片中:点击 ...
- HYSBZ(BZOJ) 4300 绝世好题(位运算,递推)
HYSBZ(BZOJ) 4300 绝世好题(位运算,递推) Description 给定一个长度为n的数列ai,求ai的子序列bi的最长长度,满足bi&bi-1!=0(2<=i<= ...
- BZOJ第一页刷题计划
BZOJ第一页刷题计划 已完成:67 / 90 [BZOJ1000]A+B Problem:A+B: [BZOJ1001][BeiJing2006]狼抓兔子:最小割: [BZOJ1002][FJOI2 ...
- B4010 菜肴制作 拓扑排序(附随机跳题代码)
今天写了一个自己的随机跳题小程序,第一次试发现跳的全是不可做题,但是在周围我一眼看见了这个题,不能说一眼看出来,但是也是比较有思路,所以就做他了! 做得比较顺利,做完之后美滋滋,突然发现样例第三组过不 ...
- 【BZOJ】初级水题列表——献给那些想要进军BZOJ的OIers(自用,怕荒废了最后的六月考试月,刷刷水题,水水更健康)
BZOJ初级水题列表——献给那些想要进军BZOJ的OIers 代码长度解释一切! 注:以下代码描述均为C++ RunID User Problem Result Memory Time Code_Le ...
- bzoj 3837 pa2013 Filary
bzoj 先搞第一问.考虑简单情况,如果\(m=2\),那么一定有个剩余类大小\(\ge \lceil\frac{n}{2}\rceil\),同时这也是答案下界 然后我们每次随机选出一个数\(a_i\ ...
- bzoj 3224 splay模板题4
再刷水题我就废了... #include<iostream> #include<cstdio> #include<algorithm> #include<cs ...
- bzoj 3223 splay模板题3
水题...貌似理解splay怎么维护数列了... 每个点维护一个size,它的位置就是它的size,区间翻转的话可以打标记,find的时候push_down,交换左右子树. #include<i ...
- bzoj 4300: 绝世好题
4300: 绝世好题 Time Limit: 1 Sec Memory Limit: 128 MB Description 给定一个长度为n的数列ai,求ai的子序列bi的最长长度,满足bi& ...
随机推荐
- vue引入elementUI 报错
在main.js里面引入import 'element-ui/lib/theme-default/index.css'中报错,无法启动项目,这是把package.json里面的webpack改成 1 ...
- 关于vc++ 6.0 编译器,点打开文件时自动关闭
装好VC++ 6.0后,点打开文件时编译器会自动关闭掉,然后在网上找到各位大神写的资料,果然是因为之前有安装vs2010冲突的缘故,然后http://download.csdn.net/source/ ...
- js 去除字符串所有空格
function trim(str){ return str.replace(/\s|\xA0/g,""); }
- 3.Springboot之修改启动时的默认图案Banner
一.SpringBoot的默认启动图案 在SpringBoot启动的时候,默认的会展示出一个spring的logo,这个图案我们用户是可以自定义的 二.自定义启动图案 方法一: Application ...
- 洛谷P3367并查集
传送门 #include <iostream> #include <cstdio> #include <cstring> #include <algorith ...
- MySQL基础 - 视图
创建视图: 假设要将posts表的前十条数据作为视图 mysql> CREATE VIEW view_test AS SELECT * FROM POSTS LIMIT 10; 使用: 可以把视 ...
- Codeforces 988F Rain and Umbrellas(DP)
题目链接:http://codeforces.com/contest/988/problem/F 题目大意: 有三个整数a,n,m,a是终点坐标,给出n个范围(l,r)表示这块区域下雨,m把伞(p,w ...
- Java事务管理之Spring+Hibernate
环境与版本 除了上一篇中的hibernate的相关lib 外 Java事务管理之Hibernate 还需要加入Spring的lib 包和如下的一些依赖包 org.aopallianceorg.aspe ...
- hdu 5943(素数间隔+二分图匹配)
Kingdom of Obsession Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Oth ...
- Firefox地址栏样式设定
我希望把Firefox的界面调整为chrome-like,一个关键的地方就是地址栏:地址栏和tab之间的距离太大了,地址栏和页面本身之间的距离也太大. 设定方法是在FF中安装stylish插件,然后加 ...