意甲冠军:给定的长度可达1000数的顺序,图像password像锁。可以上下滑动,同时会0-9周期。

每个操作。最多三个数字连续操作。现在给出的起始序列和靶序列,获得操作的最小数量,从起始序列与靶序列。

花了一天的时间。我觉得是道非常难的DP。这个阶段非常好划分,对于前面完毕的password锁就不再考虑。问题的关键是这个旋转每次能够的情况非常多。

同一时候也能够发现当I位置上确定移好后,至多影响到后两位。-> dp[i][j][k] 表示当前i位移好后,i+1 为j ,  i+2为k 的次数。

这里同一时候使用一个预处理技巧,对于一个移动操作。有向上向下两种。

当将一个值转到还有一个值,up[i][j]=(j-i+10)%10;down[i][j]=(i-j+10)%10;  i->j 的方法

在dp中必定会有对于阶段的描写叙述,一般从1開始,表达每一段。这里为了求dp[n][0][0] 在最后再补上两位。

  1. dp[0][s[0]][s[1]]=0;

刚開始0阶段,一个都未完毕的时候。即前0次移好i+1,i+2位为这种次数为0

  1. int r=up[j][t[i-1]];//①
  2. dp[i][(k+u)%10][(s[i+1]+v)%10]=min(...)//②
  1.  

这两句话是我刚開始一直困惑的地方。

首先要明白转移方程是阶段间的转移dp[i-1][...][...]->dp[i][...][...]

这样看,配合②我们发现当dp[i-1][j][k]已知,dp[i][...][...]是将其  j转为t[i-1]。(这个是理解的关键)。这里的u,v表明的是在j转为t[i-1]过程中。后两位的改变情况枚举值。

dp[i][(k+u)%10][(s[i+1]+v)%10] 这个如今就能够理解了,对于dp[i-1]的j 如今dp[i]考虑的就是上次的K了。

另一点就是标号非常乱一会是阶段的i。一会又是起始位置.......

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <map>
  4. #include <iostream>
  5. #define inf 0x3fffffff
  6. const int maxn=1010;
  7. typedef unsigned __int64 ull;
  8. using namespace std;
  9. char s[maxn],t[maxn];
  10. int dp[maxn][10][10];
  11. int up[10][10],down[10][10];
  12. int min(int a,int b)
  13. {
  14. return a<b?a:b;
  15. }
  16. void init()
  17. {
  18. int i,j;
  19. for(i=0;i<10;i++)
  20. for(j=0;j<10;j++)
  21. {
  22. up[i][j]=(j-i+10)%10;
  23. down[i][j]=(i-j+10)%10;
  24. }
  25. }
  26.  
  27. int main()
  28. {
  29. init();
  30. while(~scanf("%s%s",s,t))
  31. {
  32. memset(dp,0x3f,sizeof(dp));
  33. int i,j,k,u,v;
  34. int n=strlen(s);
  35. s[n]=s[n+1]=t[n]=t[n+1]=0;
  36. for(i=0;i<n;i++)
  37. s[i]-='0',t[i]-='0';
  38. dp[0][s[0]][s[1]]=0;//除了最初的序列。其它的dp都没有合法值
  39. for(i=1;i<=n;i++)
  40. {
  41. for(j=0;j<10;j++)//枚举两位数字的每一位
  42. {
  43. for(k=0;k<10;k++)
  44. {
  45. int r=up[j][t[i-1]];//从j转到t[i-1]的次数,将三位中最左边的数字向上转到目标序列须要的操作
  46. for(u=0;u<=r;u++)//枚举可能出现的操作
  47. {
  48. for(v=0;v<=u;v++)
  49. dp[i][(k+u)%10][(s[i+1]+v)%10]=min(dp[i][(k + u) % 10][(s[i+1] + v) % 10], dp[i-1][j][k] + r);
  50. }
  51. r=down[j][t[i-1]];
  52. for(u=0;u<=r;u++)
  53. for(v=0;v<=u;v++)
  54. dp[i][(k-u+10)%10][(s[i+1]-v+10)%10]=min(dp[i][(k - u+10) % 10][(s[i+1] - v +10) % 10], dp[i-1][j][k] + r);
  55. }
  56. }
  57. }
  58. printf("%d\n",dp[n][0][0]);
  59. }
  60.  
  61. return 0;
  62. }

HDU 4433 locker 2012 Asia Tianjin Regional Contest 减少国家DP的更多相关文章

  1. HDU-4432-Sum of divisors ( 2012 Asia Tianjin Regional Contest )

    Sum of divisors Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  2. HDU 4433 locker(DP)(2012 Asia Tianjin Regional Contest)

    Problem Description A password locker with N digits, each digit can be rotated to 0-9 circularly.You ...

  3. HDU 4436 str2int(后缀自动机)(2012 Asia Tianjin Regional Contest)

    Problem Description In this problem, you are given several strings that contain only digits from '0' ...

  4. HDU 4441 Queue Sequence(优先队列+Treap树)(2012 Asia Tianjin Regional Contest)

    Problem Description There's a queue obeying the first in first out rule. Each time you can either pu ...

  5. HDU 4431 Mahjong(枚举+模拟)(2012 Asia Tianjin Regional Contest)

    Problem Description Japanese Mahjong is a four-player game. The game needs four people to sit around ...

  6. hdu 3123 GCC (2009 Asia Wuhan Regional Contest Online)

    GCC Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total Subm ...

  7. HDU 3721 Building Roads (2010 Asia Tianjin Regional Contest) - from lanshui_Yang

    感慨一下,区域赛的题目果然很费脑啊!!不过确实是一道不可多得的好题目!! 题目大意:给你一棵有n个节点的树,让你移动树中一条边的位置,即将这条边连接到任意两个顶点(边的大小不变),要求使得到的新树的直 ...

  8. HDU 3726 Graph and Queries(平衡二叉树)(2010 Asia Tianjin Regional Contest)

    Description You are given an undirected graph with N vertexes and M edges. Every vertex in this grap ...

  9. HDU 4468 Spy(KMP+贪心)(2012 Asia Chengdu Regional Contest)

    Description “Be subtle! Be subtle! And use your spies for every kind of business. ”― Sun Tzu“A spy w ...

随机推荐

  1. Conexant声卡实现内录功能(win7)

    Conexant声卡本身没有立体声混音设备可选,所以我们采用virtual audio device,实现内录功能. [1]下载virtual audio device.下载地址:http://dow ...

  2. LeetCode总结 -- 树的性质篇

    树的性质推断是树的数据结构比較主要的操作,一般考到都属于非常easy的题目,也就是第一道入门题.面试中最好不能有问题,力求一遍写对.不要给面试官不论什么挑刺机会.LeetCode中关于树的性质有下面题 ...

  3. hdu2089(数位dp)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 题意:求区间[a,b]内不含有62或4的数的个数. 分析:数位dp,dp[pos][0]表示到第 ...

  4. Android多线程文件下载器

    本应用实现的是输入文件的网络的地址,点击button開始下载,下载过程中有进度条和后面的文本提示进度, 下载过程中button不可点击,防止反复的下载,完成下载后会进行Toast的提示显示, 而且回复 ...

  5. JUnit4.8.2来源分析-6.1 排序和过滤

    Runner.sort.Request.sortWith和Sorter.apply yqj2065很快,他们搞死. Sorter.apply().Request.sortWith()和Sortable ...

  6. 【转】C# String.Format数字格式化输出各种转换{0:N2} {0:D2} {0:C2}...

    ; //格式为sring输出 // Label1.Text = string.Format("asdfadsf{0}adsfasdf",a); // Label2.Text = & ...

  7. ProductHunt,TechCrunch和AppStore的差的值

    ProductHunt(产品狩猎)硅谷社区的新产品,起初只存在一个技术性的房子维修.然后进入YC训练营已经收到了几百美元的融资2. 这款产品的形式非常easy.粗产物似乎是一个节目的部位,加上一些评论 ...

  8. 普通的年轻状态机,纯C语言

    我们第一次接触到了状态机.在数字电路课程.计数器.串行奇偶校验.考了1连续报错电路 等待,两者都需要一个状态机模型.电路实现这些功能,与状态机的状态转移图.状态转移表是等价. 后.然后,我们联系了状态 ...

  9. erlang集群IP及port管理

    erlang集群是依靠epmd维护的,epmd是erlang集群节点间port映射的守护进程.负责维护集群内的节点连接.提供节点名称到IP地址及port的解析服务. epmd 自己定义port号 ep ...

  10. AM335x(TQ335x)学习笔记——GPIO关键驱动移植

    或按照S5PV210学习秩序.我们首先解决的关键问题.TQ335x有六个用户按钮,每个上.下.剩下.对.Enter和ESC. 我想开始学习S5PV210当同一,写输入子系统驱动器的关键问题要解决,但浏 ...