首先将边进行去重,那么有$n\geq\sqrt{m}$。

然后二分答案,转化为判定是否存在两个点它们的出边集合的并集为全集。

那么这两个点必然满足$deg_x+deg_y\geq n$。

不妨设$deg_x\geq deg_y$,那么有$deg_x\times 2\geq n$。

考虑枚举$x$,最多只会有$O(\frac{m}{n})$个$x$。

再枚举$y$,有两种判定算法:

$1.$设$f[i][j]$表示$i$是否没有指向$j$,那么只要存在$f[x][j]\ and\ f[y][j]=true$即不可行。

可以压位计算,时间复杂度$O(\frac{nm}{32})$。

$2.$枚举$y$的所有出边,通过时间戳判定是否出现在$x$中。

时间复杂度$O(\frac{m^2}{n})$。

设$S$为阈值,当$n\leq S$时用算法1,否则用算法2,则有$\frac{Sm}{32}\leq\frac{m^2}{S}$。

当$S$取$\sqrt{32m}$时,取得最优复杂度$O(m\sqrt{\frac{m}{32}})$。

总时间复杂度$O(m\log m\sqrt{\frac{m}{32}})$。

#include<cstdio>
#include<algorithm>
const int N=10005,M=100010;
int n,m,U,i,j,k,a[M],st[N],en[N],d[N],v[N],t,l,r,mid,ans;
unsigned int f[2048][64];
struct E{int x,y,z;}e[M];
inline bool cmp(const E&a,const E&b){
if(a.x!=b.x)return a.x<b.x;
if(a.y!=b.y)return a.y<b.y;
return a.z<b.z;
}
inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
bool check(int mid){
if(n>2048){
for(i=0;i<n;i++){
d[i]=0;
for(j=st[i];j<en[i];j++)if(e[j].z<=mid)d[i]++;
}
for(i=0;i<n;i++)v[i]=-1;
for(i=0;i<n;i++)if(d[i]*2>=n){
for(k=st[i];k<en[i];k++)if(e[k].z<=mid)v[e[k].y]=i;
for(j=0;j<n;j++)if(d[i]+d[j]>=n&&d[i]>=d[j]){
t=d[i];
for(k=st[j];k<en[j];k++)if(e[k].z<=mid&&v[e[k].y]<i)t++;
if(t==n)return 1;
}
}
}else{
for(i=0;i<n;i++){
for(j=0;j<U;j++)f[i][j]=~0U;
f[i][U]=0;
for(j=U<<5;j<n;j++)f[i][j>>5]|=1U<<(j&31);
}
for(i=0;i<n;i++){
d[i]=0;
for(j=st[i];j<en[i];j++)if(e[j].z<=mid)d[i]++,f[i][e[j].y>>5]^=1U<<(e[j].y&31);
}
for(i=0;i<n;i++)if(d[i]*2>=n){
for(j=0;j<n;j++)if(d[i]+d[j]>=n&&d[i]>=d[j]){
t=1;
for(k=0;k<=U;k++)if(f[i][k]&f[j][k]){t=0;break;}
if(t)return 1;
}
}
}
return 0;
}
int main(){
read(n),read(m);U=(n-1)>>5;
for(i=1;i<=m;i++){
read(e[i].x),read(e[i].y),read(e[i].z);
e[i].x--,e[i].y--;
}
std::sort(e+1,e+m+1,cmp);
for(i=1;i<=m;i++)if(i==1||e[i].x!=e[i-1].x||e[i].y!=e[i-1].y)e[++j]=e[i];
for(m=j,i=1;i<=m;i++)a[i]=e[i].z;
std::sort(a+1,a+m+1);
for(i=0,j=1;i<n;i++){
st[i]=j;
while(j<=m&&e[j].x==i)j++;
en[i]=j;
}
l=1,r=m;
while(l<=r)if(check(a[mid=(l+r)>>1]))r=(ans=mid)-1;else l=mid+1;
if(!ans)puts("No solution");else printf("%d",a[ans]);
return 0;
}

  

BZOJ3346 : Ural1811 Dual Sim Phone的更多相关文章

  1. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  2. android双待手机获取每一张SIM卡的imei

    /** * create a TelephonyInfo.java class */import java.lang.reflect.Method; import android.content.Co ...

  3. 重度使用示波器进行优化分析——一个DSDA项目回顾

    这是若干年前一个项目,最近有时间整理一下.回忆起来,印象最深刻的就是重度使用示波器辅助分析,进行优化. 项目背景是在原有项目3G+项目基础上,增加一颗2G+ Modem,使支持DSDA功能. 在介绍D ...

  4. 腾讯优测干货精选|Android双卡双待适配——隐藏在数据库中的那些秘密

    腾讯优测是专业的app自动化测试平台,除了提供兼容性测试,远程真机租用等多维度的测试服务,还有优分享-腾讯内部的移动研发测试干货精选~ 许多APP都希望获取用户通讯录联系人,利用通讯录关系链信息来丰富 ...

  5. 将helps.php或者functions.php直接进行了加载

    TP3系列中functions.php文件默认其实是空文件,很好找.我们可以直接封装代码. Laravel5系列中的path/vendor/laravel/framework/src/Illumina ...

  6. 一个简单的appium脚本

    这是一个简单的appium脚本,测试amazon购物过程的,过程包括搜索商品,然后从结果列表中选取中意的商品,然后加入购物车,等等. 它是一个最原始的脚本,对测试元素.数据.报告等未作任何的封装,后面 ...

  7. ZEN_CART_如何添加自定义页面

    按照下面的路径,添加自己的文件,就OK了 以about us页面为例, 默认模板 \includes\templates\template_default\templates\tpl_about_us ...

  8. Ultimate Guide to WhatsApp for Business 2019

    By Iaroslav Kudritskiy (Source: https://rocketbots.io/blog/the-ultimate-guide-to-whatsapp-business-a ...

  9. 重度使用示波器进行优化分析——一个DSDA项目回顾

    这是若干年前一个项目,最近有时间整理一下.回忆起来,印象最深刻的就是重度使用示波器辅助分析,进行优化. 项目背景是在原有项目3G+项目基础上,增加一颗2G+ Modem,使支持DSDA功能. 在介绍D ...

随机推荐

  1. web页面记住密码存在安全问题 - 处理方式

    现在一般安全网站都不会做记住密码功能,因为记住密码存在安全缺陷. 不考虑网络拦截问题,如果是登录页面记住密码,第二次登录,直接进入开发者模式修改类型为text即可看到密码. 处理方式: 1.把auto ...

  2. 关于快捷键 Ctrl+Alt+[方向键] 的知识

    在用PS作图时使用 Ctrl+Alt+[方向键]  组合建时屏幕莫名翻转, 平时电脑懒得维护所以略卡,我不会说一般早上起床摁了开机去上完厕所回来还--咳咳 刚按下时瞬间一黑,再黑,,继续黑--真是大吃 ...

  3. SQL中的JOIN类型解释(CROSS, INNER,OUTER),关键字ON,USING

    书上讲得明白,解了不少迷惑. SELECT e.fname, e.lname, d.name FROM employee AS e INNER JOIN department AS d ON e.de ...

  4. php开发(CI框架使用)

    年前接了一个外包项目,要求使用PHP,琢磨来琢磨去,感叹道PHP框架实在是太多了!去知乎搜索一轮,最后决定使用CI, 相关议论如下:https://www.zhihu.com/question/216 ...

  5. 在Activity和Application中使用SharedPreferences存储数据

    1.在Activity中创建SharedPreferences对象及操作方法 SharedPreferences pre=getSharedPreferences("User", ...

  6. Zero Copy 简介

    转自:http://blog.csdn.net/zzz_781111/article/details/7534649 许多web应用都会向用户提供大量的静态内容,这意味着有很多data从硬盘读出之后, ...

  7. 监听报错 TNS-00525: Insufficient privilege for operation 11gR2 + 连接报错ORA-12537: TNS:connection closed

    1.TNS-00525: Insufficient privilege for operation Started with pid= Listening on: (DESCRIPTION=(ADDR ...

  8. MATLAB中stem函数用法

    stem(Y) 将数据序列Y从x轴到数据值按照茎状形式画出,以圆圈终止.如果Y是一个矩阵,则将其每一列按照分隔方式画出. stem(X,Y)在X的指定点处画出数据序列Y.  stem(...,'fil ...

  9. UML九种图详解-外链

    http://blog.csdn.net/fanxiaobin577328725/article/details/51591482

  10. loadrunner解决在项目中的难点解决

    代码如下: vuser_init() { lr_save_string("11041331\",\"11041372\",\"11041373\&qu ...