2016.6.20——Plus One
Plus One
本题收获
1.vector<int> 和vector<char>的区别,及与int转换
从vector<int> nums 转换为int res型,直接for循环 res += nums[i];(nums中的数本就是int型,不需要再-‘0’,char型则需要用nums[i] 的ASIIC码减去 0 的ASIIC码)
从vector<char> nums 转换为int res ,则是for循环 res += nums[i] - '0';
2.不知道数组具体大小时,用size = nums.size() 表示。
且在for循环中最好不要用for(int i = 0; i < nums.size(); i++);
而用 size = nums.size() ; for(int i = 0; i < size; i++ );
第一种每次进入for循环都需要计算一遍nums的长度,而第二种只需要计算一次即可。
3.4.在程序中具体说:有关vector中 nums.push_back(res % dd)
题目:
Given a non-negative number represented as an array of digits, plus one to the number.
The digits are stored such that the most significant digit is at the head of the list.
给定一个用数组表示的非负数。将这个数加1,最重要的数在列表的最前面
题意是:给定一个用数组表示的非负数,加1后返回(还是一个数组形式),位数最高的在数组的最前面。
思路:
我的思路:将数组转化为int整数,int整数加1后,转化为数组返回。
出现问题是开始用int型,但是发现数很大,改成long long,还是不行,测试的数更大,就意识到这道题不能用这用的思路来解题。
leetcode:判断末尾是不是9,若果是变为0,不是则加1,若所有位都是9,则最后将0位置1,最后一位加个0,nums[0] = 1; nums.push_back(0);
用数组存放数,那么数肯定很大,所以不要考虑用数组转数,数转为数组的方法,出这道题的本意不是用这种方法,而是另想办法。
代码: 非常漂亮的代码,思路也很清晰!
class MyClass
{
public:
vector<int> plusOne(vector<int> &digits)
{
int n = digits.size();
for (int i = n-; i >=; i--)
{
if (digits[i] == )
{
digits[i] = ;
}
else
{
digits[i]++;
return digits;
}
}
digits[] = ;
digits.push_back();
return digits;
}
};
我的测试代码:
// PlusOne.cpp : 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include "iostream"
#include "vector"
using namespace std; class MyClass
{
public:
vector<int> plusOne(vector<int> &digits)
{
int n = digits.size();
for (int i = n-; i >=; i--)
{
if (digits[i] == )
{
digits[i] = ;
}
else
{
digits[i]++;
return digits;
}
}
digits[] = ;
digits.push_back();
return digits;
}
}; int _tmain(int argc, _TCHAR* argv[])
{
vector<int> nums = {,,,,,,,,,,,,,,,,,};
vector<int> res;
MyClass solution;
res = solution.plusOne(nums);
int n = res.size();
for (int i = ; i < n; i++)
{
cout << res[i] << " ";
}
cout << endl;
system("pause");
return ;
}
第一次出错的代码:
// Plus One.cpp : 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include "iostream"
#include "vector"
using namespace std; class Solution {
public:
vector<int> plusOne(vector<int>& digits)
{ int res = ;
vector<int> nums;
int d = ,dd = ;
int n = digits.size();
for (int i = ; i < n; i++)
{
res = res * ;
res += digits[i]; //1.强制转换的格式(int)(x) 2.digits本就是int型,不需要digits[i] - '0'
//cout << res << endl;
}
res = res + ; int res1 = res;
while (res1)
{
res1 = res1 / ;
d++;
dd = dd * ;
} dd = dd / ; for (int j = ; j < d; j++)
{
//cout << "aa" << endl;
nums.push_back(res /dd); //监视发现nums.size() 为0,因为在之前时,不知道nums的长度,所以没有设定大小。
res = res %dd; //这样的话用vector中的nums.push_back()。
dd = dd / ;
} return nums;
}
}; int _tmain(int argc, _TCHAR* argv[])
{
vector<int> nums = { , , , };
vector<int> res;
Solution solution;
res = solution.plusOne(nums);
int size = res.size();
for (int i = ;i<size; i++)
{
cout << res[i];
}
cout << endl;
system("pause");
return ;
}
简单的代码还是各种出错啊!
2016.6.20——Plus One的更多相关文章
- Stack Overflow 2016年度 20个最佳Python问题(一)
Stack Overflow 2016年度 20个最佳Python问题(一) https://zhuanlan.zhihu.com/p/25020763
- 2016.9.20 java上课作业
此程序从命令行接收多个数字,求和之后输出
- 2016 - 2 - 20 ARC知识总结(二 autorelease概念及实现)
首先祝自己生日快乐~23咯~ 一 autorelease的概念 autorelease会像C语言的自动变量那样来对待对象实例.当超出作用域(相当于变量作用域)时,对象的实例release实力方法被调 ...
- project 2016 11 20 树的多项式
#include <iostream>#include <stack>#include <cmath>#include <sstream> using ...
- 从零开始HTML(三 2016/9/20)
1.HTML表单 HTML 表单用于搜集不同类型的用户输入.<form> 元素,HTML 表单用于收集用户输入.<form> 元素 ①<input> 元素,< ...
- 从零开始HTML(二 2016/9/20)
1.布局 ① 使用 <div> 元素的 HTML 布局,<div> 元素常用作布局工具,因为能够轻松地通过 CSS 对其进行定位. <!DOCTYPE html> ...
- 2016.6.20 计算机网络复习要点第三章之CSMA/CD协议
1.最早的以太网是将许多计算机都连接到一根总线上: (1)总线的特点是:当一台计算机发送数据时,总线上的所有计算机都检测到这个数据,这种就是广播通信方式: (2)为了实现在总线上的一对一通信,可以使每 ...
- 2016 - 1 - 20 runloop学习(2)
一:CFRunLoopModeRef 1. CFRunLoopModeRef带表RunLoop的运行模式 2. 一个Runloop可以有若干个mode,每个mode又包含若干个sourse,timer ...
- 2016 - 1 - 20 runloop学习
一:Runloop基本知识 1.本质就是运行循环 2.基本作用: 2.1保证程序持续运行 2.2处理APP中的各种事件:触摸,定时器,selector... 2.3节省CPU资源,系统程序性能:它会让 ...
- 详解YUV与RGB数据格式-2016.01.20
参考文献 什么是I帧,P帧,B帧 图文详解YUV420数据格式 RGB565 与 RGB888的相互转换 最简单的基于FFmpeg的libswscale的示例(YUV转RGB)
随机推荐
- mappers标签引入映射器的四种方式
第一种方式:mapper标签,通过resource属性引入classpath路径的相对资源 <!-- Using classpath relative resources --> < ...
- Dcoker中启动mysql,并实现root远程访问
mysql容器的运行 下载mysql 5.7.19的镜像 docker pull mysql:5.7.19 运行mysql容器,端口映射为 10036 docker run --name mysql5 ...
- 解决MySQL复制出错 Last_SQL_Errno:1146
背景:我们在做数据迁移或者拆分的时候,使用Tablespace transcation 这种解决方案时,很有可能就会遇到 从库复制出错,报: Last_SQL_Errno: 1146 那么具体错误内容 ...
- 文件同步工具 lsyncd2.1.6 安装使用问题
项目有文件实时同步备份的需求,做了一下调查,比较好的解决方法是使用lsyncd工具.这里主要记录一下遇到的问题及解决方法. lsyncd 的相关介绍和对比可见: lsyncd实时同步搭建指南——取代r ...
- 【BZOJ 3326】[Scoi2013]数数 数位dp+矩阵乘法优化
挺好的数位dp……先说一下我个人的做法:经过观察,发现这题按照以往的思路从后往前递增,不怎么好推,然后我就大胆猜想,从前往后推,发现很好推啊,维护四个变量,从开始位置到现在有了i个数 f[i]:所有数 ...
- 应该更新的Java知识之常用程序库
摘自:http://www.blogbus.com/dreamhead-logs/226738702.html 在很多人眼中,Java已经是一门垂垂老矣的语言,但并不妨碍Java世界依然在前进.如果你 ...
- 【BZOJ4004】【JLOI2015】装备购买
Description 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 (1 <= i <= n; 1 < ...
- Ants on tree
Description 从前有一个策略游戏, 叫做 蚂蚁上树 游戏中有一棵 nn 个节点, 以 11 为根的有根树 初始始每个节点都为空, 游戏系统会进行两种操作 : 1 x , 表示往 xx 节点放 ...
- android 布局的两个属性 dither 和 tileMode
tileMode(平铺)tileMode(平铺) 的效果类似于 让背景小图不是拉伸而是多个重复(类似于将一张小图设置电脑桌面时的效果) dither(抖动) Dither(图像的抖动处理,当每个颜色值 ...
- 2017 3 8 练习赛 t3 路径规划
题目大意是让你在一棵树上找到一条路径使得(路径边权和*路径最小值) 最大. 这道题有两种方法. 1.点分治,考虑过重心的每条路径是否可能成为答案,枚举从根出发的每一条路径中的最小值等于总路径的最小值, ...