Java:实现杨辉三角

目录

思路

完整代码


思路

可以把杨辉三角看作是一个直角三角形,这样可以方便进行输出

以直角三角形中 i行j列 的3为例,我们可以推出: [ i ] [ j ] = [ i -1] [ j ] + [ i - 1] [ j -1] 。

同时,杨辉三角也可以看作是一个二维数组,元素都放在这个二维数组中。关于这个二维数组,我们可以通过List方法来实现。

java 复制代码
public static List<List<Integer>> generate(int numRows) {

} 

List<List<Integer>> 可以通过下面这张图来理解

List是一个一维数组,其中的每个元素可以看作是另一个一维数组。

接下来的思路是可以先把第一行的 1 单独写出来,这样我们就直接从第二行开始。

本题的难点便在于如何实现第二行往后的规律,其中又可以分为三个步骤

  1. 处理第一个元素
  2. 处理中间元素
  3. 处理最后一个元素

由于第一个元素和最后一个元素都是1,所以可以采取直接加的方式来进行。而中间元素可以通过上面提到的:**[ i ] [ j ] = [ i -1] [ j ] + [ i - 1] [ j -1]**来实现。

完整代码

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class Test1 {
    public static List<List<Integer>> generate(int numRows) {
        List<List<Integer>> ret = new ArrayList<>();
        List<Integer> list0 = new ArrayList<>();
        list0.add(1);
        ret.add(list0);
        //从第二行开始
        for (int i = 1; i < numRows; i++) {
            //处理第一个元素
            List<Integer> curRow = new ArrayList<>();
            curRow.add(1);
            //中间元素
            List<Integer> preRow = ret.get(i - 1);
            for (int j = 1; j < i; j++) {
                int val1 = preRow.get(j);
                int val2 = preRow.get(j - 1);
                curRow.add(val1 + val2);
            }
            //最后一个元素
            curRow.add(1);
            ret.add(curRow);
        }
        return ret;
    }

    public static void main(String[] args) {
        List<List<Integer>> ret = generate(4);
        for (int i = 0; i < ret.size(); i++) {
            for (int j = 0; j < ret.get(i).size(); j++) {
                System.out.print(ret.get(i).get(j) + " ");
            }
            System.out.println();
        }
    }
}

有问题的地方可以通过调试的方式来对应解决,调试部分可以看:Java刷题:移除数组中与k值相等的元素-CSDN博客

相关推荐
一只乔哇噻6 分钟前
java后端工程师进修ing(研一版 || day41)
java·开发语言·学习·算法
钮钴禄·爱因斯晨15 分钟前
深入剖析LLM:从原理到应用与挑战
开发语言·人工智能
User_芊芊君子24 分钟前
【Java】设计模式——单例、工厂、代理模式
java·设计模式·代理模式
六点半88831 分钟前
【C++】C++11 篇二
开发语言·c++
2301_8035545233 分钟前
正向代理,反向代理,负载均衡还有nginx
java·nginx·负载均衡
要开心吖ZSH34 分钟前
软件设计师备考-(十六)数据结构及算法应用(重要)
java·数据结构·算法·软考·软件设计师
DDDDDDDRDDR39 分钟前
C++容器:list
开发语言·c++·stl
向上的车轮42 分钟前
基于Java Spring Boot的云原生TodoList Demo 项目,验证云原生核心特性
java·spring boot·云原生
Elnaij44 分钟前
从C++开始的编程生活(7)——取地址运算符重载、类型转换、static成员和友元
开发语言·c++
程序员清风44 分钟前
快手一面:为什么要求用Static来修饰ThreadLocal变量?
java·后端·面试