社区讨论

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 条回复,欢迎继续交流。

正在加载回复...