2021-10-05集训


一、寻找到路(P2296)

题目传送门

尝试过用dp去写,1小时后心态炸了…

思路:queue&bfs

估分:60分

核心代码:


while(!q.empty()){
		int x1=q.front();q.pop();no3[x1]=1;
		int dian=x1;
		if(x1==ex){
			cout<<dis[x1];return 0;
		}
		x1=head[x1];
		while(x1!=0){
			if(b[edge[x1].to]==1&&no3[edge[x1].to]==0){
				q.push(edge[x1].to);
				dis[edge[x1].to]=dis[dian]+1;
			}
			x1=edge[x1].next;
		}
	}

实际得分:60分 (真不戳)


二、国王游戏(P1080)

题目传送门

原本只打算water40 ~ 60分的 暴力着暴力着就发现了其中规律,一个大臣的左右手乘积越大,就越要放到队伍后面,前面的大臣不管如何排都不会影响后面大臣(乘法交换律)。

PS:1.贪心得不到最优解 2.答案数值很大,需要高精 (Python党狂笑)

思路:数论 (狂推10分钟,调试两小时) 高精 (写完2分钟,调试两小时)

估分:70 (像我这种手残党,肯定还有玄学错误)

代码:

1.重载运算符 (现学现用)


struct moneyy{
	long long left,right;
	bool operator<(const moneyy x)const{return left*right<x.left*x.right;}
}money[1001];

2.主要数论


void I_do_not_know_how_to_do(long long x){
	int useful=0;
	for(re int i=1;i<=ls;++i)
	deal[i]*=x;
	for(re int i=1;i<=ls;++i){
		useful+=deal[i];
		deal[i]=useful%10;
		useful/=10;
	}
	while(useful!=0)
	++ls,deal[ls]=useful%10,useful/=10;
}
void Maybe_it_is_useful(long long x){
	int useful=0;
	for(re int i=1;i<=10001;++i)
	ans[i]=1;
	la=ls;
	for(re int i=la;i>=1;--i){
		useful*=10;useful+=deal[i];
		if(useful>=x)
		ans[i]=useful/x,useful=useful%x;
	}
	while(ans[la]==0){if(la==1)break;--la;}
}

PS:改了半天,代码 混乱 “整齐”

3.华丽的主函数


sort(money+1,money+n+1);
	for(re int i=1;i<=n;++i){
		I_do_not_know_how_to_do(money[i-1].left);
		Maybe_it_is_useful(money[i].right);
		What_should_I_do____GaoJin();
	}
	for(re int i=lm;i>=1;--i)
	printf("%d",maxn[i]);

实际得分:20 (玄学错误,真不戳)

感想:玄学错误出现了,有问题吗,问题不大。//TMD再也不用数论了!!!!

PS:高精写了20分,直接暴力60分。。。


三、书柜的尺寸(P2160)

题目折跃门
别问,问就是MC党

可能思路:动态规划+数论

题目太难了!!也没有部分分!!人家就是个小蒟蒻。。。 很显然我没写出来。。。


四、海底珍珠串

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

PS:样例输入中忘了写给出n,测试点中有输入n

想法:谁爱写谁写!! 判断字母数量奇偶,动态规划求解。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值