社区讨论
60pts 求助,及关于造数据的疑问,玄关
P2323[HNOI2006] 公路修建问题参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @mde3957q
- 此快照首次捕获于
- 2025/07/22 13:22 7 个月前
- 此快照最后确认于
- 2025/11/04 03:57 4 个月前
二分
CPP#include<bits/stdc++.h>
using namespace std;
struct nood{
int num,s,d,c1,c2,p;
}pjr;
vector<nood> now,a;
vector<int> ji;
int m,n,k;
int zu(int x){
return ji[x]==x?x:ji[x]=zu(ji[x]);
}
bool cmp(nood a,nood b){
return a.num<b.num;
}
bool check(int xian){
for(int i=0;i<=n;i++) ji[i]=i;
now.clear();
int x,y,z,c,sum1=0,sum2=0;
for(int i=0;i<a.size();i++){
x=a[i].s,y=a[i].d,z=a[i].c1,c=a[i].c2;
if(zu(x)==zu(y)||c>xian) continue;
now.push_back(a[i]);
if(z<=xian) now[sum1].p=1,sum2++;
else now[sum1].p=2;
if(ji[x]==x) ji[x]=zu(y);
else ji[zu(y)]=zu(x);
sum1++;
}
if(sum1<(n-1)||sum2<k) return false;
else return true;
}
int main(){
freopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
cin>>n>>k>>m;
int i=1,l=30000,r=1;
for(int i=1;i<=m-1;i++){
cin>>pjr.s>>pjr.d>>pjr.c1>>pjr.c2;
pjr.num=i;
a.push_back(pjr);
l=min(l,pjr.c2),r=max(pjr.c1,r);
}
for(int i=0;i<=n;i++){
ji.push_back(i);
}
// cout<<check(3)<<" "<<check(4)<<" "<<check(5)<<" "<<check(7)<<endl;
// cout<<l<<" "<<r<<endl;
while(l<r-1){
// cout<<l<<" "<<r<<endl;
int mid=(l+r)>>1;
// cout<<check(mid)<<endl;
if(check(mid)){
r=mid;
// cout<<"!"<<endl;
}
else l=mid;
}
bool jrt=check(r);
cout<<r<<endl;
sort(now.begin(),now.end(),cmp);
for(int i=0;i<now.size();i++){
cout<<now[i].num<<" "<<now[i].p<<endl;
}
fclose(stdin);
// fclose(stdout);
return 0;
}
想请问一下,自己在检查的时候有什么技巧,比如看代码的时候重点注意什么,怎么造数据造到那个错误的点上,非常感谢orz orz~
回复
共 0 条回复,欢迎继续交流。
正在加载回复...