WA on #3,玄关求调
查看原帖
WA on #3,玄关求调
1004245
rich_xty楼主2024/11/24 22:15

感觉可能是方案的锅

#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,dp[1010][1010]; 
int a[1010][1010],b[1010][1010];
char c[1010][1010];
int calc(int x){
	if(x==0) return 1;
	int er=0,wu=0;
	while(x%2==0){
		x/=2;
		er++;
	}
	while(x%5==0){
		x/=5;
		wu++;
	}
	return min(er,wu);
}
void dfs(int i,int j){
	if(i==1&&j==1){
		return;
	}
	if(c[i][j]=='D') dfs(i-1,j);
	else dfs(i,j-1);
	cout<<c[i][j];
}
signed main(){
	ios::sync_with_stdio(0);
	cin.tie(0); cout.tie(0);
	cin>>n;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=n;j++){
			cin>>a[i][j];
			b[i][j]=calc(a[i][j]);
		}
	for(int i=0;i<=1005;i++) dp[0][i]=dp[i][0]=1e12;
	dp[1][1]=b[1][1];
	for(int i=1;i<=n;i++){
		for(int j=1;j<=n;j++){
			if(i==1&&j==1) continue;
			if(dp[i-1][j]<=dp[i][j-1]){
				dp[i][j]=dp[i-1][j]+b[i][j];
				c[i][j]='D';
			}
			else{
				dp[i][j]=dp[i][j-1]+b[i][j];
				c[i][j]='R';
			}
		}
	}
	cout<<dp[n][n]<<'\n';
	dfs(n,n);
	return 0;
}
2024/11/24 22:15
加载中...