• 最长回文子序列

    int lpsDp(char * str,int n){
    int dp[n][n], tmp;
    memset(dp,0,sizeof(dp));
    for(int i=0; i<n; i++) dp[i][i] = 1;
    // i 表示 当前长度为 i+1的 子序列
    for(int i=1; i<n; i++){
    tmp = 0;
    //考虑所有连续的长度为i+1的子串. 该串为 str[j, j+i]
    for(int j=0; j+i<n; j++){
    //如果首尾相同
    if(str[j] == str[j+i]){
    tmp = dp[j+1][j+i-1] + 2;
    }else{
    tmp = max(dp[j+1][j+i],dp[j][j+i-1]);
    }
    dp[j][j+i] = tmp;
    }
    }
    //返回串 str[0][n-1] 的结果
    return dp[0][n-1];
    }
  • 最长递增子序列

    public class Solution {
    public int lengthOfLIS(int[] nums) {
    if(nums==null || nums.length == 0) return 0;
    int len = nums.length;
    int[] dp = new int[len];
    int[] ends = new int[len];
    ends[0] = nums[0];
    dp[0] = 1;
    int right = 0;
    int l=0;
    int r=0;
    int m=0;
    for(int i=0;i<len;i++){
    l = 0;
    r = right;
    while(l<=r){
    m = l + (r-l)/2;
    if(nums[i]>ends[m]){
    l = m + 1;
    }else{
    r = m - 1;
    }
    }
    right = Math.max(right,l);
    ends[l] = nums[i];
    dp[i] = l + 1;
    }
    int res = 0;
    for(int i=0;i<len;i++){
    res= Math.max(res,dp[i]);
    }
    return res;
    }
    }
  • Distinct Subsequences

    public class Solution {
    public int numDistinct(String s, String t) {
    int len1 = s.length();
    int len2 = t.length();
    int[][] dp = new int[len2+1][len1+1];
    for(int j=0;j<=len1;j++){dp[0][j] = 1;}
    for(int i=0;i<len2;i++){
    for(int j=0;j<len1;j++){
    if(t.charAt(i) == s.charAt(j)){
    dp[i+1][j+1] = dp[i][j]+dp[i+1][j];
    }else{
    dp[i+1][j+1] = dp[i+1][j];
    }
    }
    }
    return dp[len2][len1];
    }
    }
  • Decode Ways

    public class Solution {
    public int numDecodings(String s) {
    if(s==null || s.length()==0) return 0;
    char[] ca = s.toCharArray();
    int n = ca.length;
    if(n==1) return (ca[0]=='0')?0:1;
    int[] dp = new int[n];
    dp[0] = (ca[0]=='0')?0:1;
    dp[1] = ((ca[0]!='0' && ca[1]!='0')?1:0) + (((ca[0]!='0')&&(ca[0]-'0')*10+(ca[1]-'0')<=26)?1:0);
    if(n>2){
    for(int i=2;i<n;i++){
    dp[i] = 0;
    if(ca[i]!='0'){
    dp[i]+=dp[i-1];
    }
    if(ca[i-1]!='0' && ((ca[i-1]-'0')*10+(ca[i]-'0')<=26) ){
    dp[i]+=dp[i-2];
    }
    }
    }
    return dp[n-1];
    }
    }
  • Edit Distance

    public class Solution {
    public int minDistance(String word1, String word2) {
    int m = word1.length();
    int n = word2.length(); int[][] dp = new int[m + 1][n + 1];
    for(int i=0;i<=n;i++){dp[0][i] = i;}
    for(int i=0;i<=m;i++){dp[i][0] = i;}
    for(int i=0;i<m;i++){
    for(int j=0;j<n;j++){
    if(word1.charAt(i) == word2.charAt(j)){
    dp[i+1][j+1] = dp[i][j];
    }else{
    dp[i+1][j+1] = Math.min(Math.min(dp[i+1][j],dp[i][j+1]),dp[i][j])+1;
    }
    }
    }
    return dp[m][n];
    }
    }
  • Minimum Path Sum

    public class Solution {
    public int minPathSum(int[][] grid) {
    int m = grid.length;
    int n = grid[0].length;
    int[][] dp = new int[m][n];
    dp[0][0] = grid[0][0];
    for(int i=1;i<m;i++){
    dp[i][0] = dp[i-1][0]+grid[i][0];
    }
    for(int j=1;j<n;j++){
    dp[0][j] = dp[0][j-1]+grid[0][j];
    } for(int i=1;i<m;i++){
    for(int j=1;j<n;j++){
    dp[i][j] = Math.min(dp[i-1][j],dp[i][j-1])+grid[i][j];
    }
    }
    return dp[m-1][n-1];
    }
    }
  • Maximum Subarray

    public class Solution {
    public int maxSubArray(int[] nums) {
    int currMax=nums[0],max=nums[0];
    for(int i=1;i<nums.length;i++){
    currMax=Math.max(currMax+nums[i],nums[i]);
    max=Math.max(max,currMax);
    }
    return max;
    }
    }
  • Unique Paths II

    public class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
    int width = obstacleGrid[0].length;
    int[] dp = new int[width];
    dp[0] = 1;
    for (int[] row : obstacleGrid) {
    for (int j = 0; j < width; j++) {
    if (row[j] == 1)
    dp[j] = 0;
    else if (j > 0)
    dp[j] += dp[j - 1];
    }
    }
    return dp[width - 1];
    }
    }
  • Wildcard Matching

    boolean[] match = new boolean[m+1];
    match[0] = true;
    for (int i = 0; i < m; i++) {
    match[i+1] = false;
    }
    for (int i = 0; i < n; i++) {
    if (p.charAt(i) == '*') {
    for (int j = 0; j < m; j++) {
    match[j+1] = match[j] || match[j+1];
    }
    } else {
    for (int j = m-1; j >= 0; j--) {
    match[j+1] = (p.charAt(i) == '?' || p.charAt(i) == s.charAt(j)) && match[j];
    }
    match[0] = false;
    }
    }
    return match[m];
  • Regular Expression Matching

    public class Solution {
    public boolean isMatch(String s, String p) {
    boolean[] match = new boolean[s.length()+1];
    Arrays.fill(match,false);
    match[s.length()] = true;
    for(int i=p.length()-1;i>=0;i--){
    if(p.charAt(i) == '*'){
    for(int j=s.length()-1;j>=0;j--){
    match[j] = match[j] ||match[j+1]&&(p.charAt(i-1)=='.'||s.charAt(j)==p.charAt(i-1));
    }
    i--;
    }else{
    for(int j=0;j<s.length();j++){
    match[j] = match[j+1]&&(p.charAt(i)=='.'||p.charAt(i)==s.charAt(j));
    }
    match[s.length()] = false;
    }
    }
    return match[0];
    }
    }

DP总结的更多相关文章

  1. BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]

    1911: [Apio2010]特别行动队 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 4142  Solved: 1964[Submit][Statu ...

  2. 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...

  3. AEAI DP V3.7.0 发布,开源综合应用开发平台

    1  升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...

  4. AEAI DP V3.6.0 升级说明,开源综合应用开发平台

    AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...

  5. BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]

    1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4026  Solved: 1473[Submit] ...

  6. [斜率优化DP]【学习笔记】【更新中】

    参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...

  7. BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 9812  Solved: 3978[Submit][St ...

  8. px、dp和sp,这些单位有什么区别?

    DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...

  9. android px转换为dip/dp

    /** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...

  10. POJ 3254. Corn Fields 状态压缩DP (入门级)

    Corn Fields Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 9806   Accepted: 5185 Descr ...

随机推荐

  1. 【python】传入函数

    def add(x, y, f): return f(x) + f(y) 当我们调用add(-5, 6, abs)时,参数x,y和f分别接收-5,6和abs,根据函数定义,我们可以推导计算过程为: x ...

  2. Mybatis知识点总结

    ---恢复内容开始--- Mybatis知识点总结 1.#{}和${}的区别是什么? 答:#{}的使用场景:在表的sql映射文件中如下使用: <mapper namespace="co ...

  3. python xlwt,xlutils 在excel里面如何插入一行数据

    就是把插入行之后值重新输出来. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 import xl ...

  4. [家里蹲大学数学杂志]第432期Hardy type inequalities

    If $p>1$, $f\geq 0$, and $$\bex F(x)=\int_0^x f(t)\rd t, \eex$$ then $$\bee\label{Hardy:0 to x} \ ...

  5. view--4种Android获取View宽高的方式

    有时我们会有基于这样的需求,当Activity创建时,需要获取某个View的宽高,然后进行相应的操作,但是我们在onCreate,onStart中获取View的大小,获取到的值都是0,只是由于View ...

  6. python中利用logging包进行日志记录时的logging.level设置选择

    之前在用python自带的logging包进行日志输出的时候发现有些logging语句没有输出,感到比较奇怪就去查了一下logging文档.然后发现其在设置和引用时的logging level会影响最 ...

  7. 剑指offer习题集1

    1.打印二叉树 程序很简单,但是其中犯了一个小错误,死活找不到,写代码要注意啊 这里左右子树,要注意是node->left,结果写成root->left vector<int> ...

  8. Android 常见问题收集 (持续更新)

    gridview中设置item的高度. 一.BaseAdapter中的getView中设置 AbsListView.LayoutParams param = new AbsListView.Layou ...

  9. php curl vs python提交多维数组+文件

    总结: 1.data数据格式 2.php post 格式无需json_encode(关联数组,所以可以绕弯)  参考:http://bbs.csdn.net/topics/390645553?page ...

  10. display:none与visibility: hidden的区别

    display:none和visibility: hidden都能把网页上某个元素隐藏起来,但两者有区别: display:none ---不为被隐藏的对象保留其物理空间,即该对象在页面上彻底消失. ...