日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

LeetCode_Pascal's Triangle II_杨辉三角形II(Java实现)

發布時間:2025/4/16 java 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode_Pascal's Triangle II_杨辉三角形II(Java实现) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目描述(牛客網)

給出一個索引k,返回楊輝三角的第k行

例如,k=3,

返回[1,3,3,1].

備注:

你能將你的算法優化到只使用O(k)的額外空間嗎?

Given an index k, return the k th row of the Pascal’s triangle.

For example, given k = 3,
Return[1,3,3,1].

Note:
Could you optimize your algorithm to use only O(k) extra space?

在Pascal三角形中,每個數字都是其正上方兩個數字的和。

例:

Input: 3 Output: [1,3,3,1]

主要思想

題意是指定行數,輸出楊輝三角形的某行的元素值。

由于下一層比上一層多一個數,只需將上層的List增加1,然后向前做更新、覆蓋即可,不用額外開辟新的存儲空間;共用一個List,空間復雜度為O(k)。

實現代碼

import java.util.ArrayList;public class Solution {public ArrayList<Integer> getRow(int rowIndex) {ArrayList<Integer> list = new ArrayList<>();for (int i = 0; i <= rowIndex; i++) {list.add(1);for (int j = i - 1; j > 0; j--) {list.set(j, list.get(j - 1) + list.get(j));}}return list;} }

注意:只能第二重 for 只能向前做遍歷;如果先后遍歷做覆蓋的話,則會使得后面使用的數并非原來的數,而是更新后的數。

總結

以上是生活随笔為你收集整理的LeetCode_Pascal's Triangle II_杨辉三角形II(Java实现)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。