打牌
来源:互联网 发布:淘宝店铺合作协议 编辑:程序博客网 时间:2024/04/27 18:29
蜘蛛牌是windows xp操作系统自带的一款纸牌游戏,游戏规则是这样的:只能将牌拖到比她大一的牌上面(A最小,K最大),如果拖动的牌上有按顺序排好的牌时,那么这些牌也跟着一起移动,游戏的目的是将所有的牌按同一花色从小到大排好,为了简单起见,我们的游戏只有同一花色的10张牌,从A到10,且随机的在一行上展开,编号从1到10,把第i号上的牌移到第j号牌上,移动距离为abs(i-j),现在你要做的是求出完成游戏的最小移动距离。
Input 第一个输入数据是T,表示数据的组数。
每组数据有一行,10个输入数据,数据的范围是1,10 1,10,分别表示A到10,我们保证每组数据都是合法的。 Output 对应每组数据输出最小移动距离。 Sample Input Sample Output
每组数据有一行,10个输入数据,数据的范围是
11 2 3 4 5 6 7 8 9 10
9
考虑每一种情况
广搜 玩的是标记 深搜玩的就是 回溯
每次都有9种 变换 1到2 2到3 3到4.......
每次 标记上面的 注意 每次 变换他们的位置信息
再 回溯
#include <stdio.h>#include <string.h>int a[15],vis[15],ans;int abs(int x){ if(x<0) return -x; return x;}void dfs(int cnt,int sum){ int i,j; if(sum>=ans) return ; else { if(cnt == 9) { ans = sum; return ; } for(i = 1;i<10;i++) { if(!vis[i]) { vis[i] = 1; for(j = i+1;j<=10;j++) { if(!vis[j]) { dfs(cnt+1,sum+abs(a[i]-a[j])); break; } } vis[i] = 0; } } }}int main(){ int t,i,x; scanf("%d",&t); while(t--) { for(i = 1;i<=10;i++) { scanf("%d",&x); a[x] = i; } memset(vis,0,sizeof(vis)); ans = 10000000; dfs(0,0); printf("%d\n",ans); } return 0;}
0 0
- 打牌
- 打牌
- 打牌
- 打牌
- 出去打牌
- 打牌心得
- 1049: 打牌
- 问题 : 打牌
- 打牌导论:>
- 新年趣事之打牌
- 题目1175:打牌
- 新年趣事之打牌
- 题目1175:打牌
- 谁不爱打牌
- 谁不爱打牌
- 谁不爱打牌
- 题目1175:打牌
- 题目1175:打牌
- Set集合方法之一
- CNN训练Cifar-10技巧
- Anaconda使用conda管理技巧汇总
- MySql触发器
- 折线图柱状图封装
- 打牌
- mysql学习笔记
- LeetCode70. Climbing Stairs
- 一些面试基本知识(JAVA篇一)
- 安装Android 开发环境踩过的坑
- 自定义弹出框报错“_BSMachError Unable to insert COPY_SEND”
- [我眼中的C#]反射和特性
- 哪些微信公众号更适合技术人成长?(2017-03-10 细说云计算)
- 对于eclipse刚启动服务器出现类似于 Caused by: java.lang.ClassNotFoundException: com.zsh.first.service.ClazzService