leetcode72难动态规划
来源:互联网 发布:数据透视显示百分比 编辑:程序博客网 时间:2024/06/05 03:32
题意;经由最小的操作数把串S变为串T:
理论bfs是可行的的。
转化为对其字符串问题,
对于空字符:
s的字符为添加,T的字符为减少
不同则为修改。
用dpij表示最少得分,加一个数组sameij表示ij是否相等。
三种情况:1上面已讲
2.dpi-1j+1 也就是s的第i个字符和空对其,即删除
3.dpij-1+1添加
初值: dp0j=j dpi0=i
注意:每个i正向循环j dpi-1j-1已经是新值了。
class Solution {public: int minDistance(string word1, string word2) { int m = word1.length(), n=word2.length(); vector<vector<int> > dp(m+1,vector<int>(n+1)); for(int i=0;i<=m;i++){ for(int j=0;j<=n;j++){ if(i==0){ dp[i][j]=j; } else if(j==0){ dp[i][j]=i; } else { dp[i][j] = min(dp[i-1][j-1]+((word1[i-1]==word2[j-1])?0:1), min(dp[i][j-1]+1,dp[i-1][j]+1) ); } } } return dp[m][n]; }};然后减了一维的空间:
class Solution {public: int minDistance(string word1, string word2) { int m = word1.length(), n=word2.length(); vector<int> dp(n+1); for(int i=0;i<=m;i++){ int last; for(int j=0;j<=n;j++){ if(i==0){ dp[j]=j; } else if(j==0){ last=dp[j]; dp[j]=i; } else { int temp = dp[j]; dp[j] = min(last+((word1[i-1]==word2[j-1])?0:1), min(dp[j-1]+1,dp[j]+1) ); last=temp; } } } return dp[n]; }};
阅读全文
0 0
- leetcode72难动态规划
- 剑指offer(动态规划-LeetCode72)
- 动态规划!!!动态规划!!!
- poj 1015 动态规划 难
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- SpringMVC rest风格(Post增 Delete删 Put改 get查)
- Activity之应用进程创建流程简析
- 【Java】CopyOnWriteArrayList
- 【bzoj2318】 Spoj4060 game with probability Problem
- Avoid non-default constructors in fragments: use a default constructor plus Fragment报错的解决方法
- leetcode72难动态规划
- Java 创建对象的四种方式
- SQL语句中in和exists的区别
- PAT 1028人口普查
- 11g RAC 更改归档模式
- 网络基础(CRC、NAT、URG、PSH、tcp定时器)
- GreenDao的使用
- 2.2 linux存储管理-地址映射全过程
- Redis Zrevrank 命令