成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

LeetCode 118:楊輝三角 II Pascal's Triangle II

KaltZK / 3326人閱讀

摘要:公眾號(hào)愛寫作者愛寫給定一個(gè)非負(fù)索引,其中,返回楊輝三角的第行。在楊輝三角中,每個(gè)數(shù)是它左上方和右上方的數(shù)的和。示例輸入輸出進(jìn)階你可以優(yōu)化你的算法到空間復(fù)雜度嗎解題思路和之前寫的那篇號(hào)楊輝三角基本類似。

公眾號(hào):愛寫bug(ID:icodebugs)
作者:愛寫bug

給定一個(gè)非負(fù)索引 k,其中 k ≤ 33,返回楊輝三角的第 k 行。

Given a non-negative index k where k ≤ 33, return the kth index row of the Pascal"s triangle.

Note that the row index starts from 0.

在楊輝三角中,每個(gè)數(shù)是它左上方和右上方的數(shù)的和。

In Pascal"s triangle, each number is the sum of the two numbers directly above it.

示例:

輸入: 3
輸出: [1,3,3,1]

進(jìn)階:

你可以優(yōu)化你的算法到 O(k) 空間復(fù)雜度嗎?

解題思路:

和之前寫的那篇118號(hào)楊輝三角基本類似。這道題只是不用考慮每行輸出,只輸出最后一行。這樣只在一個(gè)數(shù)組上修改即可:該數(shù) 的值 = 該數(shù)的值+該數(shù)左邊的值之和(該數(shù)不包括第一個(gè)和最后一個(gè)數(shù))。

這道題只是不用考慮每一行輸出,只輸出最后一行。這樣只在一個(gè)數(shù)組上修改即可:該數(shù) 的值 = 該數(shù)的值+該數(shù)左邊的值之和(該數(shù)不包括第一個(gè)和最后一個(gè)數(shù))。

用兩個(gè)嵌套循環(huán),外循環(huán)是要計(jì)算的每行數(shù)組,內(nèi)循環(huán)在上一次計(jì)算的數(shù)組基礎(chǔ)上更改數(shù)值得出該行數(shù)組。

需要注意的是:內(nèi)循環(huán) j 指針應(yīng)該從每行的最后一個(gè)數(shù)開始更改。

如果 j 指針從左開始更改索引的值:

[1]

[1,1]

[1,2,1] 索引1 的值是索引 0 和 1的和,沒問題

[1,3,4,1] 索引2 的值是索引 2 和索引 1的和 為4,而不是預(yù)期的3

因?yàn)槲覀兪窃谕粋€(gè)數(shù)組里更改每個(gè)數(shù)值的,所以如果做左邊開始求值,索引 1 的值會(huì)從2變?yōu)?,此時(shí)計(jì)算索引2的值,由于該索引左邊的值已經(jīng)改變?yōu)?,該索引將不再是預(yù)期值。

起先我用的是 ArrayList()

class Solution {
    public List getRow(int rowIndex) {
        List nums = new ArrayList();
        nums.add(1);
        for (int i = 1; i <= rowIndex; i++) {
            for (int j = i - 1; j > 0; j--) {
                nums.set(j, nums.get(j) + nums.get(j - 1));
            }
            nums.add(1);
            System.out.println(nums);
        }
        return nums;
    }
}

提交時(shí)雖然能通過但是每次調(diào)用 set()、add() 導(dǎo)致性能很差很差。

Java:
class Solution {
    public List getRow(int rowIndex) {
        Integer[] nums = new Integer[rowIndex+1];//所有值被默認(rèn)置為0
        Arrays.fill(nums, 0);
        nums[0] = 1;
        for (int i = 1; i <= rowIndex; i++) {
            for (int j = i; j >0; j--) {
                nums[j] = nums[j] + nums[j-1];//當(dāng)j為1時(shí),nums[j]為0,不影響最后一個(gè)值,不用多帶帶給每行末尾賦值1
            }
        }
        return Arrays.asList(nums);//轉(zhuǎn)為List型并返回
    }
}
Python3:
class Solution:
    def getRow(self, rowIndex: int) -> List[int]:
        nums = [1] 
        for i in range(1, rowIndex+1):
            for j in range(i-1, 0, -1):
                nums[j] +=nums[j-1]
            nums.append(1) # 需要給末尾索引賦值1
        return nums

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/75183.html

相關(guān)文章

  • LeetCode 118楊輝三角 II Pascal&#039;s Triangle II

    摘要:公眾號(hào)愛寫作者愛寫給定一個(gè)非負(fù)索引,其中,返回楊輝三角的第行。在楊輝三角中,每個(gè)數(shù)是它左上方和右上方的數(shù)的和。示例輸入輸出進(jìn)階你可以優(yōu)化你的算法到空間復(fù)雜度嗎解題思路和之前寫的那篇號(hào)楊輝三角基本類似。 公眾號(hào):愛寫bug(ID:icodebugs)作者:愛寫bug 給定一個(gè)非負(fù)索引 k,其中 k ≤ 33,返回楊輝三角的第 k 行。 Given a non-negative index...

    xiaodao 評(píng)論0 收藏0
  • leetcode # 118:Pascal&#039;s Triangle 楊輝三角

    摘要:楊輝三角給定一個(gè)非負(fù)整數(shù),生成楊輝三角的前行。在楊輝三角中,每個(gè)數(shù)是它左上方和右上方的數(shù)的和。另外可以在內(nèi)層循環(huán)加判斷在不等于時(shí)才加上,這樣可省略代碼段,但是這個(gè)會(huì)在每次進(jìn)入第一次循環(huán)后判斷一次。本著減少資源消耗的原則,應(yīng)當(dāng)提到外面。 118:Pascals Triangle 楊輝三角 Given a non-negative integer numRows, generate the...

    CKJOKER 評(píng)論0 收藏0
  • leetcode # 118:Pascal&#039;s Triangle 楊輝三角

    摘要:楊輝三角給定一個(gè)非負(fù)整數(shù),生成楊輝三角的前行。在楊輝三角中,每個(gè)數(shù)是它左上方和右上方的數(shù)的和。另外可以在內(nèi)層循環(huán)加判斷在不等于時(shí)才加上,這樣可省略代碼段,但是這個(gè)會(huì)在每次進(jìn)入第一次循環(huán)后判斷一次。本著減少資源消耗的原則,應(yīng)當(dāng)提到外面。 118:Pascals Triangle 楊輝三角 Given a non-negative integer numRows, generate the...

    gggggggbong 評(píng)論0 收藏0
  • Leetcode 118&119 Pascal&#039;s Triangle

    摘要:首先要對(duì)特殊情況進(jìn)行處理小于等于的情況。然后循環(huán),每一次產(chǎn)生一個(gè),個(gè)有個(gè)元素,每個(gè)的第一個(gè)和第個(gè)元素都是對(duì)于中間的那些元素,則找出前一個(gè)的對(duì)應(yīng)位置的兩個(gè)元素加和即可得到。這一道題只要求返回形式的一行的元素即可。 118 Pascals Triangle 題目詳情 Given numRows, generate the first numRows of Pascals triangle....

    laznrbfe 評(píng)論0 收藏0
  • [LeetCode] 119. Pascal&#039;s Triangle II

    Problem In Pascals triangle, each number is the sum of the two numbers directly above it. Example: Input: 3Output: [1,3,3,1]Follow up: Could you optimize your algorithm to use only O(k) extra space? S...

    CompileYouth 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<