https://www.hackerrank.com/contests/w31/challenges
Accurate Sorting 检查每个数字距离原位是否都不超过1
Zero-One Game 计算可以被删去的数字个数
Spanning Tree Fraction 最优比率生成树,分数规划+Kruscal
Colliding Circles 算出两两圆之间最后被合并的概率,由期望的线性性计算对答案的贡献
#include<bits/stdc++.h>
typedef long double ld;
int n,k,r[];
int main(){
scanf("%d%d",&n,&k);
long long s1=,s2=;
for(int i=;i<n;++i)scanf("%d",r+i),s1+=r[i],s2+=r[i]*r[i];
ld p=;
for(int i=n;i>n-k;--i){
long long a=1ll*i*(i-);
p=p*ld(a-)/ld(a);
}
printf("%.12Lf",acos(-)*(s2+(s1*s1-s2)*(-p)));
return ;
}
Nominating Group Leaders 权值分块维护莫队,bzoj原题
#include<bits/stdc++.h>
const int N=1e5+;
int T,n,m,a[N],as[N],id[N],B,t1[N],t2[N];
struct Q{
int l,r,x,I;
bool operator<(Q w)const{
if(id[l]!=id[w.l])return id[l]<id[w.l];
if(r!=w.r)return (r<w.r)!=(id[l]&);
return I<w.I;
}
}qs[N];
int cnt[N],*l1[N],*l2[N],*l3[N],*l4[N],*r4[N];
int mem[N*],*mp;
void ins(int x,int t){
if(t){
int a=l1[x][t];
++l2[t][a];
++l3[t][a>>];
}
}
void del(int x,int t){
if(t){
int a=l1[x][t];
--l2[t][a];
--l3[t][a>>];
}
}
int find(int t){
for(int i=;i<t2[t];i+=)if(l3[t][i>>]){
int j=i;
while(!l2[t][j])++j;
return l4[t][j];
}
return -;
}
void ins(int x){
del(x,cnt[x]);
ins(x,++cnt[x]);
}
void del(int x){
del(x,cnt[x]);
ins(x,--cnt[x]);
}
int main(){
for(scanf("%d",&T);T;--T){
scanf("%d",&n);
for(int i=;i<n;++i){
scanf("%d",a+i);
}
mp=mem;
memset(mem,,sizeof(mem));
memset(cnt,,sizeof(cnt));
memset(t1,,sizeof(t1));
memset(t2,,sizeof(t2));
for(int i=;i<n;++i)++t1[a[i]];
for(int i=;i<n;++i)l1[i]=mp-,mp+=t1[i];
for(int i=;i<n;++i){
for(int j=;j<=t1[i];++j){
l1[i][j]=t2[j]++;
}
}
for(int i=;i<=n;++i){
l4[i]=r4[i]=mp,mp+=t2[i];
l3[i]=mp,mp+=t2[i];
l2[i]=mp,mp+=t2[i];
}
for(int i=;i<n;++i){
for(int j=;j<=t1[i];++j){
*r4[j]++=i;
}
}
scanf("%d",&m);
B=(n+)/sqrt(m+)+;
for(int i=;i<n;++i)id[i]=i/B;
for(int i=;i<m;++i){
scanf("%d%d%d",&qs[i].l,&qs[i].r,&qs[i].x);
qs[i].I=i;
}
std::sort(qs,qs+m);
int L=,R=-;
for(int i=;i<m;++i){
int l=qs[i].l,r=qs[i].r;
while(L>l)ins(a[--L]);
while(R<r)ins(a[++R]);
while(L<l)del(a[L++]);
while(R>r)del(a[R--]);
as[qs[i].I]=find(qs[i].x);
}
for(int i=;i<m;++i)printf("%d\n",as[i]);
}
return ;
}
Split Plane 由欧拉定理,线段划分出的联通块数=边数-点数+1+线段构成的联通块个数,扫描线处理一下,要开long long !!!
具体实现:横竖各扫一次,计算每条线段与其他线段的交点个数,特判一下端点
用可持久化线段树和并查集维护线段构成的联通块,支持插入、删除一条与扫描线垂直的线段,将当前区间内的线段标记为并起来,细节较多,具体见代码
#include<bits/stdc++.h>
#define int long long
const int N=1e5+;
struct seg{
int x,l,r;
bool operator<(seg w)const{return x!=w.x?x<w.x:l<w.l;}
}s1[N],s2[N],ss[N];
int p1,p2,ans,V,E,C;
int T,n,xs[N*],ys[N*],xp=,yp=;
void gx(int&x){x=std::lower_bound(xs,xs+xp,x)-xs;}
void gy(int&x){x=std::lower_bound(ys,ys+yp,x)-ys;} void rb(seg*a,int&ap){
std::sort(a,a+ap);
int sp=;
for(int i=,j=;i<ap;i=j){
while(j<ap&&a[i].x==a[j].x)++j;
ss[sp++]=a[i++];
for(;i<j;++i){
if(ss[sp-].r<a[i].l)ss[sp++]=a[i];
else if(ss[sp-].r<a[i].r)ss[sp-].r=a[i].r;
}
}
for(int i=;i<sp;++i)a[i]=ss[i];
ap=sp;
} struct ev{
int tp,x,a,b;
bool operator<(ev e)const{return x!=e.x?x<e.x:tp<e.tp;}
}e[N*]; int t0[N*],bit[N*];
void add(int w,int a){
if(t0[w]==||t0[w]+a==)for(int x=w+;x<N*;x+=x&-x)bit[x]+=a;
t0[w]+=a;
}
int sum(int w){
int s=;
for(++w;w;w-=w&-w)s+=bit[w];
return s;
}
int ch[N*][],p,ws[N],f[N*],pv;
bool fd[N*],ed[N*];
int gf(int x){
int a=x,c;
while(x!=f[x])x=f[x];
while(x!=f[a])c=f[a],f[a]=x,a=c;
return x;
}
int newnode(){
++p;
ch[p][]=ch[p][]=;
f[p]=p;
fd[p]=;
ed[p]=;
return p;
}
void mg(int a,int b){
f[gf(a)]=gf(b);
}
void dfs(int w){
if(fd[w])return;
fd[w]=;
for(int d=;d<;++d)if(ch[w][d]){
mg(w,ch[w][d]);
dfs(ch[w][d]);
}
}
void find(int w,int L,int R,int l,int r){
if(!w)return;
if(l<=L&&R<=r){
if(pv)mg(w,pv);
dfs(w);
pv=w;
return;
}
int M=L+R>>;
if(l<=M)find(ch[w][],L,M,l,r);
if(r>M)find(ch[w][],M+,R,l,r);
}
int ins(int w,int L,int R,int x,int y){
int u=newnode();
if(L==R){
ws[y]=u;
}else{
int M=L+R>>;
if(x<=M)ch[u][]=ins(ch[w][],L,M,x,y),ch[u][]=ch[w][];
else ch[u][]=ins(ch[w][],M+,R,x,y),ch[u][]=ch[w][];
}
return u;
}
int del(int w,int L,int R,int x){
if(L==R)return ;
int u=newnode();
int M=L+R>>;
if(x<=M)ch[u][]=del(ch[w][],L,M,x),ch[u][]=ch[w][];
else ch[u][]=del(ch[w][],M+,R,x),ch[u][]=ch[w][];
if(!ch[u][]&&!ch[u][])return ;
return u;
}
void cal(seg*a,int ap,seg*b,int bp,bool cc){
memset(t0,,sizeof(t0));
memset(bit,,sizeof(bit));
p=;
int rt=newnode();
int ep=;
for(int i=;i<ap;++i)e[ep++]=(ev){,a[i].x,a[i].l,a[i].r};
for(int i=;i<bp;++i){
e[ep++]=(ev){,b[i].l,b[i].x,i};
e[ep++]=(ev){,b[i].r+,b[i].x,i};
}
std::sort(e,e+ep);
for(int i=;i<ep;++i){
if(e[i].tp==){
int s=sum(e[i].b)-sum(e[i].a-);
V+=s;
E+=s-;
if(!t0[e[i].a])V+=,++E;
if(!t0[e[i].b])V+=,++E;
if(cc&&s){
pv=;
find(rt,,,e[i].a,e[i].b);
--C;
}
}else if(e[i].tp==){
add(e[i].a,);
if(cc)rt=ins(rt,,,e[i].a,e[i].b);
}else{
add(e[i].a,-);
if(cc)rt=del(rt,,,e[i].a);
}
}
if(cc)
for(int i=;i<bp;++i){
int a=gf(ws[i]);
if(!ed[a])ed[a]=;
else --C;
}
}
signed main(){
for(scanf("%lld",&T);T;--T){
scanf("%lld",&n);
p1=p2=;
xp=yp=;
for(int i=,x1,y1,x2,y2;i<n;++i){
scanf("%lld%lld%lld%lld",&x1,&y1,&x2,&y2);
xs[xp++]=x1;
xs[xp++]=x2;
ys[yp++]=y1;
ys[yp++]=y2;
if(x1>x2)std::swap(x1,x2);
if(y1>y2)std::swap(y1,y2);
if(x1==x2)s1[p1++]=(seg){x1,y1,y2};
else if(y1==y2)s2[p2++]=(seg){y1,x1,x2};
}
std::sort(xs,xs+xp);
xp=std::unique(xs,xs+xp)-xs;
std::sort(ys,ys+yp);
yp=std::unique(ys,ys+yp)-ys;
rb(s1,p1);
rb(s2,p2);
for(int i=;i<p1;++i){
gx(s1[i].x);
gy(s1[i].l);
gy(s1[i].r);
}
for(int i=;i<p2;++i){
gy(s2[i].x);
gx(s2[i].l);
gx(s2[i].r);
}
V=E=;
C=p1+p2;
cal(s1,p1,s2,p2,);
cal(s2,p2,s1,p1,);
// printf("[V=%g E=%d C=%d]",V*.5,E,C);
printf("%lld\n",E-V/++C);
}
return ;
}
hackerrank Week of Code 31的更多相关文章
-
【HackerRank Week of Code 31】Colliding Circles
https://www.hackerrank.com/contests/w31/challenges/colliding-circles/problem 设E(n)为序列长度为n时的期望值. \[ \ ...
-
hackerrankWeek of Code 31
hackerrankWeek of Code 31 A.Beautiful Word B.Accurate Sorting C.Zero-One Game D.Spanning Tree Fracti ...
-
HackerRank Week of Code 26
好像这次week of code不是很难= = A int main(){ int n; int m; cin >> n >> m; cout<<(n+)/*)/) ...
-
【hackerrank week of code 26】Hard Homework
[题目链接]:https://www.hackerrank.com/contests/w26/challenges/hard-homework/problem [题意] 给你一个式子:sin(x)+s ...
-
hackerrank [Week of Code 33] Bonnie and Clyde
任意门 题意:给一个图,每次询问给三个点a,b,c,问是否存在一条从a到c,一条b到c的路径除c外无交点. 双连通分量缩点建出圆方树是必须的,然后我们需要判断c是否在a到b的路径上,或者c的某个相邻的 ...
-
【枚举约数】HackerRank - Week of Code 26 - Satisfactory Pairs
题意:给你一个正整数n,问你存在多少个正整数对a,b(a<b),满足条件:存在正整数x,y,使得ax+by=n. 就预处理出n以内所有数的约数,然后暴力枚举a,暴力枚举x,然后枚举n-ax的所有 ...
-
Hackerrank: Week of Code 36
Cut a Strip 题目简述:给定$n \times m$的矩阵$a[][]$,要求选择一个$x \times 1(1 \leq x \leq k)$的(连续)子矩阵并清零后,找到最大和的(连续) ...
-
Hadoop Exit Code 含义
经常遇到的exception是: 1. PipeMapRed.waitOutputThreads(): subprocess failed with code N ............ 2. T ...
-
hive subprocess failed with code X 的错误码对应信息
PipeMapRed.waitOutputThreads(): subprocess failed with code X ,这里code X对应的信息如下:error code 1: Operati ...
随机推荐
-
set的用法
set提供一个不重复元素的集合,一般不能直接修改元素.因为这样可能会造成重复元素因此必须删除旧元素,再插入新元素.看下面程序:分析每句的功能.#include<set>#include&l ...
-
GCC源码自动编译-python脚本
一.前言 目前因机器OS GCC版本太老,导致无法编译一些新版本软件,所以写了一个自动编译GCC的python脚本,操作系统是比较老的suse 10, 很多系统自动软件版本都很低,所以此脚本一般可适用 ...
-
MySQL 数据库设计 笔记与总结(2)逻辑设计
[实例演示 —— 实体之间的关系] [逻辑设计的工作] ① 将需求转化为数据库的逻辑模型 ② 通过 ER 图的形式对逻辑模型进行展示 ③ 同所选用的具体的 DBMS 系统无关 [名词解释] 候选码可以 ...
-
Js 旋转平滑特效
效果图 源码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...
-
JD-GUI on Ubuntu 13.04 64-bit
Java Decompiler (jd-gui) is a cute little tool I like using when working in Java. Unfortunately it o ...
-
ACM经典算法之字符串处理:字符串替换
语法:replace(char str[],char key[],char swap[]); 參数: str[]:在此源字符串进行替换操作 key[]:被替换的字符串,不能为空串 swap[]:替换的 ...
-
A.01.11—模块的输出—输出复用和可配
对于输入来说,高边输入与低边输入可配,那对于输出来说,它有哪些可配的情况呢. 下图中展示了2种常见的类型. 第一种为同一驱动芯片内部的情况.对于OPL与ODL,即PWM低端输出和固态的低端输出,它们是 ...
-
关于asyncio知识(二)
一.asyncio之—-入门初探 通过上一篇关于asyncio的整体介绍,看过之后基本对asyncio就有一个基本认识,如果是感兴趣的小伙伴相信也会尝试写一些小代码尝试用了,那么这篇文章会通过一个简单 ...
-
jdk1.6 改 jdk1.7或jdk1.8(改回也可以)(图文详解)
不多说,直接上干货! 第一步:设置默认使用的JDK和JRE环境 具体步骤:菜单window->preferences->java->Installed JRES 点中了,右边的窗口 ...
-
Datawhale MySQL 训练营 Task1:MySQL 安装与数据库基础
安装 平台 Windows X64; MySQL: 直接去 MySQL 官网 下载:点击即可安装:安装过程中可能会要求 python3.7; 可以去安装一个 python3.7; 可视化工具:Navi ...