lintcode 843. 数字翻转 个人想法及C++代码
2018-03-21 19:10
337 查看
今天做lintcode算法题的时候,一开始被这个题难住了,第一想法就是去搜答案,但是网上没有找到,没想到最后居然能自己给做出来,看到最后通过的时候开心的无以复加,可能这就是刷题最大的乐趣吧。这里把代码和思路贴出来给大家分享一下,希望可以帮助到有需要的人,如果有不对的和可以改进的,欢迎大家批评指正。
原题:
给你一个
注意事项输入的数组长度
样例给出 array =
这是一个动态规划题,主要的思路是根据数组翻转前一步最后一位是0还是1来计算这一步翻成结尾是0或1各需要翻转几次。
用二维的容器保存状态,dp[i][j],到数组第i位,以j结尾时需要翻转几步,j的取值只有0或者1。class Solution {
public:
/**
* @param nums: the array
* @return: the minimum times to flip digit
*/
int flipDigit(vector<int> &nums) {
// Write your code here
int size=nums.size();
vector<vector<int> > dp(size+1,vector<int>(2,0));
for(int i=1;i<=size;++i)
{
if(nums[i-1])
{
dp[i][0]=min(dp[i-1][0]+1,dp[i-1][1]+1);
dp[i][1]=dp[i-1][1];
}
else
{
dp[i][0]=min(dp[i-1][0],dp[i-1][1]);
dp[i][1]=dp[i-1][1]+1;
}
}
return dp[size][0]<dp[size][1]?dp[size][0]:dp[size][1];
}
};
附上代码,新手上路,欢迎批评指正,或者在评论区大家一起讨论!
原题:
给你一个
01构成的数组。请你找出最小翻转步数,使得数组满足以下规则:
1的后面可以是
1或者
0,但是
0的后面必须是
0。
注意事项输入的数组长度
n <= 100000。
样例给出 array =
[1,0,0,1,1,1], 返回
2。
解释: 把两个0翻转成1。给出 array =
[1,0,1,0,1,0], 返回
2。
解释: 把第二个1和第三个1都翻转成0。
这是一个动态规划题,主要的思路是根据数组翻转前一步最后一位是0还是1来计算这一步翻成结尾是0或1各需要翻转几次。
用二维的容器保存状态,dp[i][j],到数组第i位,以j结尾时需要翻转几步,j的取值只有0或者1。class Solution {
public:
/**
* @param nums: the array
* @return: the minimum times to flip digit
*/
int flipDigit(vector<int> &nums) {
// Write your code here
int size=nums.size();
vector<vector<int> > dp(size+1,vector<int>(2,0));
for(int i=1;i<=size;++i)
{
if(nums[i-1])
{
dp[i][0]=min(dp[i-1][0]+1,dp[i-1][1]+1);
dp[i][1]=dp[i-1][1];
}
else
{
dp[i][0]=min(dp[i-1][0],dp[i-1][1]);
dp[i][1]=dp[i-1][1]+1;
}
}
return dp[size][0]<dp[size][1]?dp[size][0]:dp[size][1];
}
};
附上代码,新手上路,欢迎批评指正,或者在评论区大家一起讨论!
相关文章推荐
- [lintcode]843. 数字翻转
- 第16周项目5-编程处理C++代码(输入m、n两个数字,从第m行起的n行代码将作为注释使用)
- LintCode-数字翻转
- LintCode【简单】53. 翻转字符串 。代码及思路
- 数字雨C++代码(转)
- 找出一串数字中,n个连续的数之和最大c++代码实例及运行结果
- C/C++个人代码风格
- C++代码札记(二)猴子吃桃问题、输入10个数字,输出其中最大的3个数字。
- 2018省赛第九届蓝桥杯C/C++ B组 个人代码 递增三元组
- 编程算法 - 圆圈中最后剩下的数字(循环链表) 代码(C++)
- PKI/CA: 《电子政务数字证书格式规范(局字486)》总结:个人、机构、设备、代码签名四种证书区别_20160922_七侠镇莫尛貝
- 生成8位26个字母和数字的全排列(密码字典,密钥)c++代码(非递归高效直接)
- 年近40的我又开始了写代码的工作,重新写了一个C++的数据库连接池的类,个人觉得挺方便的
- 编写代码实现从输入流中分析出数字串(C++)
- 【笔记】C++ (仅使用一维数组,不用blas)实现 logistic regression代码错误经验总结, 数据集为mnist手写体数字
- 有关C++异常安全的一点个人想法
- 找出一串数字中,n个连续的数之和最大c++代码实例及运行结果
- LintCode 代码 翻转数
- LintCode【简单】35. 翻转链表 。代码及思路
- 找出一串数字中,n个连续的数之和最大c++代码实例及运行结果