1. 杨辉三角

给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。

在杨辉三角中,每个数是它左上方和右上方的数的和。

示例:
输入:
输出:
[
[],
[,],
[,,],
[,,,],
[,,,,]
]

java

class Solution {
public List<List<Integer>> generate(int numRows) {
List<List<Integer>> rs = new ArrayList<List<Integer>>();
List<Integer> prior = null;
for(int i=1;i<=numRows;i++){
List<Integer> tmp = new ArrayList<>();
for(int j=0;j<i;j++){
if(j==0||j==i-1){
tmp.add(1);
}else{
tmp.add(prior.get(j-1)+prior.get(j));
}
}
rs.add(tmp);
prior = tmp;
}
return rs;
}
}

php

class Solution {

    /**
* @param Integer $numRows
* @return Integer[][]
*/
function generate($numRows) {
$rs = [];
for($i=1;$i<=$numRows;$i++){
$tmp = [];
for($j=0;$j<$i;$j++){
if($j==0||$j==$i-1){
array_push($tmp,1);
}else{
array_push($tmp,$rs[$i-2][$j-1]+$rs[$i-2][$j]);
}
}
array_push($rs,$tmp);
}
return $rs;
}
}

2.杨辉三角的第 

给定一个非负索引 k,其中 k ≤ 33,返回杨辉三角的第 行。

示例:
输入: 3
输出: [1,3,3,1]

直接使用组合公式

C(n,i) = n!/(i!*(n-i)!)

则第(i+1)项是第i项的倍数=(n-i)/(i+1);

java

class Solution {
public List<Integer> getRow(int rowIndex) {
List<Integer> rs= new ArrayList<>();
long m = 1;
for(int i=0;i<=rowIndex;i++){
rs.add((int)m);
m = m*(rowIndex-i)/(i+1);
}
return rs;
}
}

注:

  m不能为int,会发生溢出

php

class Solution {

    /**
* @param Integer $rowIndex
* @return Integer[]
*/
function getRow($rowIndex) {
$m = 1;
$rs = [];
for($i=0;$i<=$rowIndex;$i++){
array_push($rs,(int)$m);
$m = $m*($rowIndex-$i)/($i+1);
}
return $rs;
}
}

3.买卖股票的最佳时机

(1)给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。

如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润。

示例 1:
输入: [7,1,5,3,6,4]
输出: 5
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格。 示例 2:
输入: [7,6,4,3,1]
输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。

java

class Solution {
public int maxProfit(int[] prices) {
if(prices.length==0) return 0;
int min = prices[0];
int max = 0;
for(int i=1;i<prices.length;i++){
if(prices[i]<min){
min = prices[i];
}else if(prices[i]-min>max){
max = prices[i]-min;
}
}
return max;
}
}

php

class Solution {

    /**
* @param Integer[] $prices
* @return Integer
*/
function maxProfit($prices) { $min = max($prices);
$max = 0;
foreach ($prices as $key => $value) {
if($value<$min){
$min = $value;
}else if($value-$min>$max){
$max = $value-$min;
}
}
return $max;
}
}

(2)给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。

注意:不能同时参与多笔交易(必须在再次购买前出售掉之前的股票)。

示例 1:
输入: [7,1,5,3,6,4]
输出: 7
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6-3 = 3 。 示例 2:
输入: [1,2,3,4,5]
输出: 4
解释: 在第 1 天(股票价格 = 1)的时候买入,在第 5 天 (股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
注意你不能在第 1 天和第 2 天接连购买股票,之后再将它们卖出。
因为这样属于同时参与了多笔交易,你必须在再次购买前出售掉之前的股票。 示例 3:
输入: [7,6,4,3,1]
输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。

java

class Solution {
public int maxProfit(int[] prices) {
if(prices.length==0||prices.length==1) return 0;
int max = 0;
for(int i =0;i<prices.length-1;i++){
if(prices[i]<prices[i+1])
max += prices[i+1]-prices[i];
}
return max;
}
}

php

class Solution {

    /**
* @param Integer[] $prices
* @return Integer
*/
function maxProfit($prices) {
if(count($prices)==0||count($prices)==1) return 0;
$max = 0;
for($i=0;$i<count($prices)-1;$i++) {
if($prices[$i]<$prices[$i+1]){
$max = $max+$prices[$i+1]-$prices[$i];
}
}
return $max;
}
}

算法练习之杨辉三角,杨辉三角的第 k 行,买卖股票的最佳时机的更多相关文章

  1. python买卖股票的最佳时机--贪心/蛮力算法简介

    开始刷leetcode算法题 今天做的是“买卖股票的最佳时机” 题目要求 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更 ...

  2. LeetCode初级算法之数组:122 买卖股票的最佳时机 II

    买卖股票的最佳时机 II 题目地址:https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-ii/ 给定一个数组,它的第 i ...

  3. 【初级算法】2.买卖股票的最佳时机 II

    题目: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必 ...

  4. 算法-买卖股票的最佳时机II

    01.题目分析 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格.你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票. ...

  5. [LeetCode] 122. 买卖股票的最佳时机ii best-time-to-buy-and-sell-stock-ii(贪心算法)

    思路: 只要第二天的价格高于第一天,就进行交易.(这样的话就默认可以同一天内先卖出再买进) class Solution(object): def maxProfit(self, prices): & ...

  6. 算法基础_递归_求杨辉三角第m行第n个数字

    问题描述: 算法基础_递归_求杨辉三角第m行第n个数字(m,n都从0开始) 解题源代码(这里打印出的是杨辉三角某一层的所有数字,没用大数,所以有上限,这里只写基本逻辑,要符合题意的话,把循环去掉就好) ...

  7. 【LeetCode-面试算法经典-Java实现】【121-Best Time to Buy and Sell Stock(最佳买卖股票的时间)】

    [121-Best Time to Buy and Sell Stock(最佳买卖股票的时间)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Say you have ...

  8. 【Leetcode】买卖股票-贪心算法

    题目: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必 ...

  9. 给定一个非负索引 k,其中 k ≤ 33,返回杨辉三角的第 k 行。

    从第0行开始,输出第k行,传的参数为第几行,所以在方法中先将所传参数加1,然后将最后一行加入集合中返回. 代码如下: public static List<Integer> generat ...

随机推荐

  1. linux用户的问题

    最近在开发的时候遇到一个问题: 我在某个项目下的某个文件夹内写了一个可以单独run的A.py文件,这个文件里面的代码可以调用kubernetes的python接口来请求kubernetes上的信息(比 ...

  2. ARTS-week3

    Algorithm 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度.不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件 ...

  3. python iter()函数迭代器

    迭代器为类序列对象提供了一个类序列的接口.python的迭代无缝地支持序列对象,而且它还允许程序员迭代非序列类型,包括用户定义的对象.迭代器用起来很灵巧,你可以迭代不是序列但表现处序列行为的对象,例如 ...

  4. python通过LXML库读取xml命名空间

    xml实例版本: <a> <city:table xmlns:city="city"> <heilongjiang name="citys& ...

  5. test20190905 ChiTongZ

    100+22+90=212.前两道题不错,但T3 没什么意义. 围观刘老爷超强 T1 解法. ChiTongZ的水题赛 [题目简介] 我本可以容忍黑暗,如果我不曾见过太阳. 考试内容略有超纲,不超纲的 ...

  6. A - Happy Birthday, Polycarp!

    Codeforces Round #606 (Div. 2, based on Technocup 2020 Elimination Round 4) A. Happy Birthday, Polyc ...

  7. git version info & svn version info map(七)

    To generate the same version number as SVN, we can generate the same version number as SVN with the ...

  8. 洛谷P1577 切绳子题解

    洛谷P1577 切绳子题解 题目描述 有N条绳子,它们的长度分别为Li.如果从它们中切割出K条长度相同的 绳子,这K条绳子每条最长能有多长?答案保留到小数点后2位(直接舍掉2为后的小数). 输入输出格 ...

  9. linux命令之------Linux文档编辑

    1.Vi和vim三种模式 (1)命令模式:移动光标 (2)插入模式:编辑文档 (3)末行模式:保存退出 不同模式操作示意图: 其中wq是保存退出,wq!强制保存退出:q不保存退出:q!强制不保存退出. ...

  10. Bacteria(优先队列)

    题目链接:http://codeforces.com/gym/101911/problem/C 问题简述:给定n个细胞以及每个细胞的大小,相同的细胞能进行融合,如果能融合到只剩1个细胞则输出需要额外增 ...