带备忘录的动态规划【leetcode931】

带备忘录的动态规划【leetcode931】

1. C++中vector<vector >的定义

vector<vector<int> > A;//正确的定义方式
vector<vector<int>> A;//C++11后支持

2. C++中vector<vector >的大小

//vector<vector<int> >A中的vector元素的个数
len = A.size();
//vector<vector<int> >A中第i个vector元素的长度
len = A[i].size();

3. C++中初始化数组

//头文件:string.h
//memset是将从地址s开始,字节长度为n的内存全部赋值为ch(注意是每一个字节都赋值为ch)
void *memset(void *s, int ch, size_t n);
//例:
chatr str[100]
memset(str,0,100);
int a[100];
memset(a,0,sizeof(a));

4. 源代码

class Solution {
public:
    int minFallingPathSum(vector<vector<int>>& matrix)
     {
       int num=matrix.size();
       int num2=matrix[num-1].size();
       int mins[102];
       int keep[102];
       memset(mins,0,sizeof(mins));
        memset(keep,0,sizeof(keep));
         //初始最后一排
       for(int i=0;i<num2;i++)
        {
            mins[i]=matrix[num-1][i];
        }
       for(int j=num-2;j>=0;j--)
       {
           //首和尾
           keep[0]=min(mins[1],mins[0])+matrix[j][0];
           keep[num2-1]=min(mins[num2-1],mins[num2-2])+matrix[j][num2-1];
            for(int i=1;i<num2-1;i++)
            {
            keep[i]=min(mins[i-1]+matrix[j][i],mins[i]+matrix[j][i]);
            keep[i]=min(mins[i+1]+matrix[j][i],keep[i]);
            }
            for(int i=0;i<num2;i++)
            {
            mins[i]=keep[i];  
            }

       }
       int ans=mins[0];
       for(int i=1;i<num2;i++)
        {
            if(mins[i]<ans)
            ans=mins[i];
        }
     return ans;
    }
};

5. 参考链接

参考链接1: link.
参考链接2: link.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值