Run ID | 作者 | 问题 | 语言 | 测评结果 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|
56283 | zhangweiran | 田忌赛马 | C++ | 通过 | 0 MS | 252 KB | 666 | 2024-11-09 22:56:07 |
#include<iostream> #include<cstdio> #include<algorithm> using namespace std; const int N=10; int a[N]; int b[N]; int n,x; int vis[N]; int check(){ int res=0; for(int i=1;i<=n;i++){ if(b[i]>=a[i]+x){ res++; } } if(2*res>n) return 1; return 0; } void dfs(int cur){ if(cur==n+1){ if(check()) { for(int i=1;i<=n;i++) printf("%d ",b[i]); printf("\n"); return ; } } for(int i=1;i<=n;i++){ if(vis[i]) continue; b[cur]=i; vis[i]=1; dfs(cur+1); vis[i]=0; b[cur]=0; } return ; } int main(void){ scanf("%d%d",&n,&x); for(int i=1;i<=n;i++) scanf("%d",&a[i]); dfs(1); return 0; }