首页 > 代码库 > 【USACO 1.3】Combination Lock
【USACO 1.3】Combination Lock
/*TASK:comboLANG:C++URL:http://train.usaco.org/usacoprob2?a=E6RZnAhV9zn&S=comboSOLVE:自己做,想的是5*5*5*2-重复计算的。官方题解是超级简单地写个判断枚举每一种解是否可行(n^3),题目没给n的范围,我就认为不可以用O(n^3)的算法。*/#include <iostream>#include <algorithm>#include <cstdio>#include <cstring>#define ll long longusing namespace std;int n,a[30][40];ll ans=1;int main() { freopen("combo.in","r",stdin); freopen("combo.out","w",stdout); scanf("%d",&n); for(int i=1;i<=2;i++) for(int j=1;j<=3;j++) scanf("%d",&a[i][j]); ll s=min(5,n); if(n<=5)ans=s*s*s; else for(int j=1;j<=3;j++) ans*=s-min(s,(ll)min(abs(a[1][j]-a[2][j]),n-abs(a[1][j]-a[2][j]))); printf("%lld\n",s*s*s*2-ans);}
【USACO 1.3】Combination Lock
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。