首页 > 其他分享 >AtCoder Beginner Contest 324 DF题题解

AtCoder Beginner Contest 324 DF题题解

时间:2023-10-15 16:33:07浏览次数:37  
标签:AtCoder cnt val Beginner int 题解 double include dp

比赛链接

D - Square Permutation

其实比较简单,但是比赛时候脑子不转了,竟然在尝试枚举全排列,然后算了一下复杂度直接不会做了。

正解应该是枚举完全平方数,底数枚举到 \(sqrt(10^{14})\) 即可,因为 n 最大为 13。

然后统计一下这个完全平方数各个数字出现了多少个,和读入的比较一下是否相等即可。

注意这个完全平方数不能超过 n 位,且不足 n 位时前面要补 0。

#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<queue>
#include<set>
#include<map>
#include<vector>
#include<iomanip>
#include<ctime>
#include<stack>
using namespace std;
int n,ans,a[10],dig[10];
string s;
int main()
{
    ios::sync_with_stdio(false);
	cin>>n>>s;
	for(int i=1;i<=n;i++) a[s[i-1]-'0']++;
	for(int i=0;i<10000000;i++){
		long long x=1ll*i*i;
		memset(dig,0,sizeof(dig));
		for(int i=1;i<=n;i++) dig[x%10]++,x/=10;
		if(x) continue;
		for(int i=0;i<=9;i++){
			if(dig[i]!=a[i]){
				ans--;
				break;
			}
		}
		ans++;
	}
	cout<<ans;
    return 0;
}

F - Beautiful Path

这种算法其实以前学过,叫做 01分数规划,即分子和分母都是一些数字的和,要求最大/小的这个分数值。

好久没做的我赛场上以为是个dp,写了好久最后一直wa,赛后发现他不满足最优子结构(到达u节点的分数最大时并不一定是最优解,因为可能分子和分母都很大,导致后面一些价值高的边“贬值”了)。

正解是二分这个最大值 X,然后判断 \(\max \{ \sum (a_i-Xb_i) \} > 0\) 是否成立。

这种形式是可以用dp来求的。

日语题解里好像提到了一种可以优化到O(n)的Dinkelbach 算法,没看懂。

#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<queue>
#include<set>
#include<map>
#include<vector>
#include<iomanip>
#include<ctime>
#include<stack>
using namespace std;
const double eps=1e-10;
const int maxn=200005;
int n,m,cnt,p[maxn],vis[maxn];
double dp[maxn];
struct node{
	int v,next;
	double val,w;
}e[maxn];
void insert(int u,int v,double val,double w){
	cnt++;
	e[cnt].v=v;
	e[cnt].val=val;
	e[cnt].w=w;
	e[cnt].next=p[u];
	p[u]=cnt;
}
bool check(double x){
	memset(dp,0,sizeof(dp));
	memset(vis,0,sizeof(vis));
	vis[1]=1;
	for(int u=1;u<=n;u++){
		if(!vis[u]) continue;
		for(int i=p[u];i!=-1;i=e[i].next){
			int v=e[i].v;
			if(vis[v]) dp[v]=max(dp[v],dp[u]+e[i].val-e[i].w*x);
			else dp[v]=dp[u]+e[i].val-e[i].w*x;
			vis[v]=1;
		}
	}
	if(dp[n]>0) return 1;
	return 0; 
}
int main()
{
    ios::sync_with_stdio(false);
    memset(p,-1,sizeof(p));
	memset(dp,-1,sizeof(dp));
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		int u,v;
		double w,val;
		cin>>u>>v>>val>>w;
		insert(u,v,val,w);
	}
	double l=0,r=10000;
	while(abs(r-l)>eps){
		double mid=(l+r)/2;
		if(check(mid)) l=mid;
		else r=mid;
	}
	cout<<fixed<<setprecision(10)<<l;
    return 0;
}

比赛总结

忙了一天之后打比赛,累得甚至趴着桌子上睡了一会,崩掉大概是我能理解的。

ABC过的速度还可以,但是D题卡住了,于是先去做E,然后F题又假了。

比赛前还是应该调一下状态,注意休息。

标签:AtCoder,cnt,val,Beginner,int,题解,double,include,dp
From: https://www.cnblogs.com/yinyuqin/p/17765767.html

相关文章

  • 网络规划设计师真题解析--HDLC(帧类型)
    HDLC协议通信过程如下图所示,其中属于U帧的是(13)。(2021)A.仅SABME          B.SABME和UA C.SABME、UA和REJ,1    D.SABME、UA和I,0,0答案:B解析:HDLC帧类型如图:bit01234567I帧0N(S)发送帧序号3bit,取值23(0-7)P/FN(R)下一个预期要接收帧的序号3bit,取值23(0-7)S帧10S......
  • ABC324题解
    A/B赛时没打。C暴力判断是相等s[i]==t还是替换了一个字符,或者是添加/删除了一个字符。最后两个判断只需要交换一下\(s\)和\(t\)的顺序就可以共用一个函数了。D注意到\(N\le13\),所以平方数不会超过\(v=10^{13}\),很容易想到暴力枚举\(\sqrtv\)以内的数,判断是否......
  • P9517 drink 题解
    P9517drink题解Part1提示题目传送门欢迎大家指出错误并私信这个蒟蒻欢迎大家在下方评论区写出自己的疑问(记得@这个蒟蒻)Part2更新日志2023-08-1218:06文章完成2023-08-1415:53文章通过审核Part3解析这道题考场上用的查找做的。先用一个结构体分别表示......
  • P9686 Judg. 题解
    P9686Judg.题解Part1提示题目传送门欢迎大家指出错误并私信这个蒟蒻欢迎大家在下方评论区写出自己的疑问(记得@这个蒟蒻)Part2更新日志2023-10-0215:50文章完成2023-10-0412:37文章通过审核Part3解析一道简单模拟。这道题最简单的方法就是直接在for循......
  • P8741 [蓝桥杯 2021 省 B] 填空问题 题解
    P8741[蓝桥杯2021省B]填空问题题解题目传送门欢迎大家指出错误并联系这个蒟蒻更新日志2023-05-0923:19文章完成2023-05-0923:20通过审核2023-06-2021:03优化了文章代码格式试题A:空间【解析】本题考察计算机存储的基础知识,只要掌握空间存储的换算方法,就能......
  • P8679 [蓝桥杯 2019 省 B] 填空问题 题解
    P8679[蓝桥杯2019省B]填空问题题解题目传送门欢迎大家指出错误并联系这个蒟蒻更新日志2023-05-2521:02文章完成2023-05-2711:34文章通过审核2023-06-2021:03优化了文章代码格式试题A:组队【解析】本题是一道经典的DFS搜索题,每次对各号位的选手进行DFS,......
  • P8684 [蓝桥杯 2019 省 B] 灵能传输 题解
    P8684[蓝桥杯2019省B]灵能传输题解Part1提示题目传送门欢迎大家指出错误并私信这个蒟蒻欢迎大家在下方评论区写出自己的疑问(记得@这个蒟蒻)Part2更新日志2023-06-2021:46文章完成2023-07-0308:57文章通过审核2023-08-2118:14更改了文章格式,使文章看起......
  • 算法题解——买卖股票的最佳时机
    解题思路先考虑最简单的「暴力遍历」,即枚举出所有情况,并从中选择最大利润。设数组prices的长度为n,由于只能先买入后卖出,因此第1天买可在未来n−1天卖出,第2天买可在未来n-2天卖出……以此类推,共有\[(n-1)+(n-2)+\cdots+0=\frac{n(n-1)}{2}\]种情况,时间复......
  • Atcoder Beginner Contest 324 F Beautiful Path 题解-分数规划
    为了更好的阅读体验,请点击这里分数规划小技巧:尽可能将式子写成存在某种取值,使得不等式成立的形式。不然可能需要绕几个弯才能想出来。题目链接题目大意:给出一个DAG,每条边有一个\(b_i,c_i\),保证从编号小的边向编号大的边连边,且\(1\)到\(n\)必有路径,求\(1\)到\(n\)......
  • CF1204D2 Kirk and a Binary String (hard version) 题解
    CF1204D2KirkandaBinaryString(hardversion)题解分析先来分析\(01\)串的最长不下降子序列。全是\(0\)显然是不下降的,如果中间出现一个\(1\),为了维护不下降的性质,后面就只能全是\(1\)。一句话概括一下,\(0\)后面能跟\(0,1\),\(1\)后面只能跟\(1\)。现在来分析这......