CSP_20140304无线网络

题目描述:

解题思路: 

我们可以看作是单源最短路问题!(从1到2)

一共是n+m个点,我们先逐个判断每两个点之间是否有边,只要是两个点之间距离小于等于r就用邻接表连接起来,并且是双向边。

dis[i][j]表示从1到i经过j个特殊点(新加的点)的最少需要点的个数,我们可以将每条边看作单位1,那么也就表示从1到i经过j个特殊点(新加的点)的最短路!

然后用bfs一层层去搜索更新,逐个判断是否满足条件,去更新。(详细看代码)

#include<bits/stdc++.h>
using namespace std;

const int N=210,M=N*N;
int n,m,k,r;
#define  x  first
#define  y  second
#define  LL long long
//typedef pair<int,int> PLL;
#define  PII  pair<int,int>
PII w[N];
int e[M],ne[M],idx,h[N];
int dis[N][N];//dis[i][j]表示从1到i经过j个特殊点的最小经过的点的个数 
int res=0x3f3f3f3f;
void add(int a,int b)  //将边加入到邻接表中 
{
	e[idx]=b,ne[idx]=h[a],h[a]=idx++;
	return ;
}
bool check(PII a,PII b)  //判断是否满足条件 
{
	LL x=a.x-b.x;
	LL y=a.y-b.y;
	return  x*x+y*y<=(LL)(r*r);
}
void bfs()
{
	queue<PII> q;
	memset(dis,0x3f,sizeof(dis));
	dis[1][0]=0; 
	q.push({1,0});
	while(q.size())
	{
		PII t=q.front();
		q.pop();
		for(int i=h[t.x];i!=-1;i=ne[i]) //i是边的索引idx,e[i] 是连的那个点 
		{
			int x=e[i],y=t.y;//x是搜索的下一个点,y是特殊点的个数 
			if(x>n) y++; //如果下一个点是特殊点,那么从当前点更新的话,y应该加一(下一个点本身) 
			if(y<=k)  //如果y<=k 满足题目要求 
			{
				if(dis[x][y]>dis[t.x][t.y]+1) //判断是否更短,然后更新 
				{
					dis[x][y]=dis[t.x][t.y]+1;
					q.push({x,y}); //放入队列 
				}
			}
		}
	}
	for(int i=0;i<=k;i++)     //最后寻找增加0~k个特殊点的情况下,最短的路径 
	{
		res=min(res,dis[2][i]);
	}
	res--; //减去第二个点本身 
	return ;
}
int main()
{
	memset(h,-1,sizeof(h));
	cin>>n>>m>>k>>r;
	for(int i=1;i<=n+m;i++) cin>>w[i].x>>w[i].y;
	
	for(int i=1;i<=n+m;i++)
		for(int j=i+1;j<=n+m;j++)
			if(check(w[i],w[j])) 
				add(i,j),add(j,i);
	
	bfs();
	cout<<res<<endl;
	return 0;
} 
  • 遇到的问题:

(LL)r*r 与(LL)(r*r)不同:前者是long了第一个r然后再乘以r就扩展成long long,但是后者是先(r*r)这时候已经爆int了,所以再long long也出错了!

  • #define 与typedef的区别:

https://blog.csdn.net/qq_42795061/article/details/121691567

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
运行这段代码出现TypeError: '<' not supported between instances of 'datetime.date' and 'int'错误csp_info.replace(to_replace=r'^\s*$', value=np.nan, regex=True, inplace=True) csp_info.dropna(inplace=True) csp_info['year'] = csp_info['DealTime'].str.split('/', expand=True)[0] csp_info['month'] = csp_info['DealTime'].str.split('/', expand=True)[1] csp_info['day'] = csp_info['DealTime'].str.split('/', expand=True)[2].str.split(' ', expand=True)[0] stu_info_copy = stu_info[['bf_StudentID','cla_id']] # csp_info_copy = csp_info.copy() csp_info['csp_date'] = 0 csp_info['Mon'] = 0 for i in range(csp_info['csp_date'].shape[0]): csp_info['csp_date'].iloc[i] = str(csp_info['year'].iloc[i]) + '-' + str(csp_info['month'].iloc[i]) + '-' + str( csp_info['day'].iloc[i]) csp_info['Mon'].iloc[i] = float(str(csp_info['MonDeal'].iloc[i]).split('-')[1]) # print(csp_info) csp_info['csp_date'] = pd.to_datetime(csp_info['csp_date']).dt.date csp_info_copy = csp_info[['bf_StudentID', 'csp_date', 'Mon']] csp_num = csp_info_copy.groupby(['csp_date']).count().reset_index() csp_info_date_all = [] for i in range(csp_num.shape[0]): csp_info_date_all.append(str(csp_num['csp_date'].iloc[i])) print(len(csp_info_date_all)) stu_info_copy_merge = pd.merge(stu_info_copy, csp_info_copy, on='bf_StudentID', how='left') stu_info_copy_merge = stu_info_copy_merge.fillna(0) Mon_arr = [] for i in range(len(classId)): stu_info_copy_merge_id = stu_info_copy_merge.drop(stu_info_copy_merge[stu_info_copy_merge['cla_id'] != classId[i]].index) print(stu_info_copy_merge_id) csp_date = [] Mon= [] Num= [] csp_money = stu_info_copy_merge_id[['csp_date', 'Mon']].groupby('csp_date').sum().reset_index() csp_num = stu_info_copy_merge_id[['csp_date','Mon']].groupby('csp_date').count().reset_index() print(csp_money) print(csp_num)
03-21

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值