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博客

相关推荐
人活一口气8 小时前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
像我这样帅的人丶你还10 小时前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端
NE_STOP10 小时前
vibe Coding -- 小项目实战
java
未秃头的程序猿16 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户2986985301417 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉17 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯17 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手17 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记17 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码17 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python