1、



String to Integer (atoi)

Implement atoi to convert a string to an integer.

Hint: Carefully consider all possible input cases. If you want a challenge, please do not see below and ask yourself what are the possible input cases.

Notes: It is intended for this problem to be specified vaguely (ie, no given input specs). You are responsible to gather all the input requirements up front.

spoilers alert... click to show requirements for atoi.

Requirements for atoi:

The function first discards as many whitespace characters as necessary until the first non-whitespace character is found. Then, starting from this character, takes an optional initial plus or minus sign followed by as many numerical
digits as possible, and interprets them as a numerical value.

The string can contain additional characters after those that form the integral number, which are ignored and have no effect on the behavior of this function.

If the first sequence of non-whitespace characters in str is not a valid integral number, or if no such sequence exists because either str is empty or it contains only whitespace characters, no conversion is performed.

If no valid conversion could be performed, a zero value is returned. If the correct value is out of the range of representable values, INT_MAX (2147483647) or INT_MIN (-2147483648) is returned.

分析:此题非经常见,此题的错误处理是比較简单的。假设不能转换则变为0。注意溢出问题时先使用long long来保存结果,然后做转换,而不是long,非常多系统下long int和int的值范围是同样的。

代码例如以下:

class Solution {
public:
int atoi(const char *str) {
if(!str){
return 0;
}
while(*str==' '){
++str;
}
bool minus = false;
if(*str == '-'){
minus = true;
++str;
}else if(*str == '+'){
++str;
}
long long result = 0;
while(*str!='\0'){
if(*str <= '9' && *str >= '0'){
result = result*10+*str-'0';
if( !minus && result>INT_MAX ){
return INT_MAX;
}else if( minus && -result < INT_MIN ){
return INT_MIN;
}
}else{
break;
}
++str;
}
return minus==true? -(int)result:(int)result;
}
};

2、Best Time to Buy and Sell Stock

Say you have an array for which the ith element is the price of a given stock on day i.

If you were only permitted to complete at most one transaction (ie, buy one and sell one share of the stock), design an algorithm to find the maximum profit.

分析:求一个股票的最大收益。这个题在阿里面试过程中遇到过。只是做了变形,后来才发现leetcode中类似的题目。之前有同学去面试也出过类似的题目。求一个数组前面数字减去后面数字的绝对值的最大值,这都是一类题目,解题思路差点儿相同。

解题思路:保存一个截止到i的股票价格的最小值和股票收益的最大值,假设prices[i]>股票价格的最小值,则有收益,比較此时收益和最大收益,更新最大收益。假设prices[i]<i前面股票价格的最小值,则更新最小值。

代码例如以下:

class Solution {
public:
int maxProfit(vector<int> &prices) {
if(prices.size()<2){
return 0;
}
int maxProfit = 0;
int tempProfit = 0;
int minPrice = 0;
for(int i=0; i<prices.size(); ++i){
if( i==0 ){
minPrice = prices[i];
}
if( prices[i] < minPrice ){
minPrice = prices[i];
}else{
tempProfit = prices[i] - minPrice;
if(tempProfit > maxProfit){
maxProfit = tempProfit;
}
}
}
return maxProfit;
}
};

3、Best Time to Buy and Sell Stock II

Say you have an array for which the ith element is the price of a given stock on day i.

Design an algorithm to find the maximum profit. You may complete as many transactions as you like (ie, buy one and sell one share of the stock multiple times). However, you may not engage in multiple transactions at the same time (ie, you must sell
the stock before you buy again).

分析:此题和上一题是一系列。可是能够多次买入卖出,感觉有点不知道怎样求解,但细致想,画出波浪线时,能够想到是求每一个上升阶段的最大最小差值的和,想到这里就不难实现了。注意各种參数。

代码例如以下:

class Solution {
public:
int maxProfit(vector<int> &prices) {
if( prices.size()<2 ){
return 0;
}
int maxProfit = 0; //最大收益
int preProfit = 0; //上一上升阶段的收益
int curMinPrice = 0; //当前最小值
int curMaxProfit = 0; //当前最大收益
int buyIndex = 0; //上次购买的时间
for(int i=0; i<prices.size();++i){
if(i==0){
curMinPrice = prices[i];
buyIndex = i;
continue;
}
if(prices[i] < prices[i-1]){ //在下降阶段
if(buyIndex != i-1){ //假设是第一个下降点
curMinPrice = prices[i];
curMaxProfit = 0;
maxProfit += preProfit;
buyIndex = i;
}else{
if(prices[i] < curMinPrice){ //在下降阶段
curMinPrice = prices[i];
buyIndex = i;
}
}
}else{ //一直在上升阶段
preProfit = prices[i] - curMinPrice;
if(preProfit > curMaxProfit){
curMaxProfit = preProfit;
}
if(i == prices.size()-1){
maxProfit += preProfit;
}
}
}
return maxProfit;
}
};

4、Best Time to Buy and Sell Stock III

Say you have an array for which the ith element is the price of a given stock on day i.

Design an algorithm to find the maximum profit. You may complete at most two transactions.

Note:

You may not engage in multiple transactions at the same time (ie, you must sell the stock before you buy again).

分析:此题和前面的类似。可是不同的是最多买两次的收益最大,首先想到的是将数组从0到数组末尾点N分别分成两半,计算分别计算左右的最大盈,利。将其加和,从这N个数中取最大的就为最多两次收益最大的值。可是这样求解局部最大盈利时子问题反复求解,想到利用空间换时间的方法,利用数组保存前一半的最大盈利,第i+1个点的盈利能够利用i个点的盈利求得;然后从后往前遍历,求i点后的最大盈利,同一时候将i点的最大盈利与前面数组i-1的位置元素相加(为啥是i-1位置呢。由于同一个点不能同一时候买入卖出),更新总最大盈利。

代码例如以下:

class Solution {
public:
int maxProfit(vector<int> &prices) {
int length = prices.size();
if(length<2){
return 0;
}
int maxProfit = 0; //用数组记录从開始到每一个元素位置的最大收益
int* profit1 = new int[length];
int buyPrice = 0;
int tempProfit = 0;
for(int i=0; i<length; ++i){
if(i==0){
profit1[i] = 0;
buyPrice = prices[i];
continue;
}
if(prices[i] > buyPrice){//假设大于前面的最小值
tempProfit = prices[i] - buyPrice;
if(tempProfit > profit1[i-1]){
profit1[i] = tempProfit; //更新最大盈利
}else{
profit1[i] = profit1[i-1];
}
}else{ //假设小于前面的最小值,则更新最小值
buyPrice = prices[i];
profit1[i] = profit1[i-1];
}
}
//从后往前遍历,计算每一个元素后的最大收益
int sellPrice = 0;
int postMaxProfit = 0;
int tempPrice = 0;
for(int i=length-1; i>0; --i){
if(i==length-1){
sellPrice = prices[i];
maxProfit = profit1[i];
continue;
}
if(prices[i]<sellPrice){
tempPrice = sellPrice - prices[i];
if(tempPrice > postMaxProfit){
postMaxProfit = tempPrice;
}
}else{
sellPrice = prices[i];
}
if(postMaxProfit+profit1[i-1] > maxProfit){
maxProfit = postMaxProfit+profit1[i-1];
}
}
delete[] profit1;
return maxProfit;
} };

leetcode day6 -- String to Integer (atoi) &amp;&amp; Best Time to Buy and Sell Stock I II III的更多相关文章

  1. LeetCode:Best Time to Buy and Sell Stock I II III

    LeetCode:Best Time to Buy and Sell Stock Say you have an array for which the ith element is the pric ...

  2. LeetCode之“动态规划”:Best Time to Buy and Sell Stock I && II && III && IV

    Best Time to Buy and Sell Stock I 题目链接 题目要求: Say you have an array for which the ith element is the ...

  3. [LeetCode] 递推思想的美妙 Best Time to Buy and Sell Stock I, II, III O(n) 解法

    题记:在求最大最小值的类似题目中,递推思想的奇妙之处,在于递推过程也就是比较求值的过程,从而做到一次遍历得到结果. LeetCode 上面的这三道题最能展现递推思想的美丽之处了. 题1 Best Ti ...

  4. [Leetcode][JAVA] Best Time to Buy and Sell Stock I, II, III

    Best Time to Buy and Sell Stock Say you have an array for which the ith element is the price of a gi ...

  5. Best Time to Buy and Sell Stock I,II,III [leetcode]

    Best Time to Buy and Sell Stock I 你只能一个操作:维修preMin拍摄前最少发生值 代码例如以下: int maxProfit(vector<int> & ...

  6. Leetcode 8. String to Integer (atoi) atoi函数实现 (字符串)

    Leetcode 8. String to Integer (atoi) atoi函数实现 (字符串) 题目描述 实现atoi函数,将一个字符串转化为数字 测试样例 Input: "42&q ...

  7. 【leetcode】String to Integer (atoi)

    String to Integer (atoi) Implement atoi to convert a string to an integer. Hint: Carefully consider ...

  8. [leetcode] 8. String to Integer (atoi) (Medium)

    实现字符串转整形数字 遵循几个规则: 1. 函数首先丢弃尽可能多的空格字符,直到找到第一个非空格字符. 2. 此时取初始加号或减号. 3. 后面跟着尽可能多的数字,并将它们解释为一个数值. 4. 字符 ...

  9. Leetcode 8. String to Integer (atoi)(模拟题,水)

    8. String to Integer (atoi) Medium Implement atoi which converts a string to an integer. The functio ...

随机推荐

  1. 基于visual Studio2013解决面试题之1404希尔排序

     题目

  2. on、where、having的区别(转载)

    on.where.having的区别 on.where.having这三个都可以加条件的子句中,on是最先执行,where次之,having最后.有时候如果这先后顺序不影响中间结果的话,那最终结果是相 ...

  3. axure篇

    QQ:1187362408 欢迎技术交流和学习 axure篇(axure rp 7.0): TODO: 1.汉化组件及菜单选项 界面组件汉化: 菜单汉化: 2,了解axure 控制器中各项功能区中的菜 ...

  4. HDU5090模拟,hash

    /* HDU 5090 算是一道简单模拟题.但当中有非常深的hash思想 这是本人的第一道hash题 更是本人的第一道纸质代码不带编译不带执行提交AC的题 值得纪念 废话讲这么多之后,讲述题中思想 因 ...

  5. 上一篇括号配对让人联想起catalan数,顺便转载一篇归纳的还不错的文章

    转载请注明来自souldak,微博:@evagle 怎么样才是合法的组合? 只要每一时刻保证左括号的数目>=右括号的数目即可. 直接递归就行,每次递归加一个括号,左括号只要还有就能加,右括号要保 ...

  6. adb 命令使用的时候出现Error

    在使用adb 命令行的时候会出现Error 重启adb server 即可,使用管理员运行Cmd 命令窗口 adb kill-server adb start-server 如果是连接真机查看的时候再 ...

  7. UpdateWindow API函数的作用很明显

    待续 摘自<Delphi深度历险>

  8. 在DLL中封装的VCL窗体Tab键响应的问题

    在DLL中的子窗体不会响应Tab按键的,这个时候就需要手动去指定Tab键的操作,但是前提是主窗体要向这个窗体发送一个消息,一个Tab键按下的消息.基本顺序是这样的: 1. 主窗体用Hook技术捕获Ta ...

  9. Android中ProgressDialog的应用

    下面通过实现点击按钮来显示加载框,2秒后自动消失. 1.首先在layout的xml中添加一个按钮: <Button android:id="@+id/button1" and ...

  10. 配置虚拟主机并更改Apache默认解析路径

    配置虚拟主机,非常easy 改动以下文件: 加入以下几句话 <VirtualHost *:80> ##ServerAdmin webmaster@dummy-host2.example.c ...