Java算法OJ(12)


目录

1.前言

2.正文

2.1Fib数列

2.2单词搜索

2.3杨辉三角

3.小结


1.前言

哈喽大家好吖,今天来分享几道的练习题,欢迎大家在评论区多多交流,废话不多说让我们直接开始吧。

2.正文

2.1Fib数列

题目:斐波那契数列_牛客题霸_牛客网


解法1:

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);int num = in.nextInt();int[] dp = new int[num + 1];dp[1] = 1;dp[2] = 1;for (int i = 3; i <= num; i++) {dp[i] = dp[i - 1] + dp[i - 2];}System.out.println(dp[num]);}
}
  • 时间复杂度:O(n),仅需一次遍历。

  • 空间复杂度:O(n),使用数组存储中间结果。

  • 优化空间:若只需最终结果,可用两个变量替代数组,将空间复杂度降至O(1)。

  • 注意事项:当num较大时,int可能溢出,可改用longBigInteger


解法2:

    public static void main(String[] args) {Scanner in = new Scanner(System.in);int num = in.nextInt();int first = 1;int second = 1;int temp;for (int i = 3; i <= num; i++) {temp = second;//先把变量second保存起来second = first + second;first = temp;}System.out.println(second);}
特性说明
时间复杂度O(n),与动态规划方法相同
空间复杂度O(1),仅需3个变量,远优于动态规划的O(n)
边界处理若输入 num = 1 或 2,直接输出初始值1,无需进入循环
溢出问题当 num 较大时,int 可能溢出,可改用 long 或 BigInteger

2.2单词搜索

题目:单词搜索_牛客题霸_牛客网


import java.util.*;public class Solution {int[] dx = new int[]{-1, 1, 0, 0};int[] dy = new int[]{0, 0, -1, 1};public boolean exist (String[] board, String word) {// write code herechar[][] grid = new char[board.length][board[0].length()];for(int i = 0; i < board.length; i++){grid[i] = board[i].toCharArray();}boolean[][] visited = new boolean[grid.length][grid[0].length];for(int i = 0; i < grid.length; i++){for(int j = 0; j < grid[0].length; j++){if(word.charAt(0) == grid[i][j]){if(dfs(grid, word, 0, i, j, visited)) return true;}}}return false;}private boolean dfs(char[][] grid, String word, int depth, int x, int y, boolean[][] visited) {// 所有字符判断完了,返回trueif(depth == word.length()) {return true;}// 越界或访问过或字符不等,返回falseif(x < 0 || x >= grid.length || y < 0 || y >= grid[0].length || visited[x][y] || grid[x][y] != word.charAt(depth)){return false;}// 尝试4个方向,有一个成功就行visited[x][y] = true;for(int i = 0; i < 4; i++){if(dfs(grid, word, depth + 1, x + dx[i], y + dy[i], visited)){return true;}}// 回溯visited[x][y] = false;return false;}
}

1. 输入处理

  • 将输入的字符串数组 board 转换为二维字符数组 grid,便于后续操作。

  • 初始化一个与 grid 大小相同的 visited 数组,用于标记已访问的单元格。


2. 深度优先搜索(DFS)

  • 目标:从矩阵的每个单元格出发,尝试匹配单词的每个字符。

  • 步骤

    1. 起点选择:遍历矩阵的每个单元格,如果当前单元格的字符与单词的第一个字符匹配,则从该位置开始 DFS。

    2. 递归匹配

      • 如果当前字符匹配,标记该单元格为已访问。

      • 向四个方向(上下左右)递归搜索下一个字符。

      • 如果某个方向匹配成功,返回 true

    3. 回溯

      • 如果当前路径无法匹配完整单词,撤销当前单元格的访问标记(visited[x][y] = false),并返回 false


3. 边界条件

  • 成功条件:递归深度等于单词长度时,说明单词已完全匹配,返回 true

  • 失败条件

    • 当前单元格越界。

    • 当前单元格已访问过。

    • 当前单元格字符与单词的当前字符不匹配。

2.3杨辉三角

题目:杨辉三角_牛客题霸_牛客网

import java.util.Scanner;
public class Main {public static void main(String[] args) {Scanner sc=new Scanner(System.in);int n=sc.nextInt();int[][] array=new int[n][n];for(int i=0;i<n;i++){for(int j=0;j<=i;j++){if(j==0||j==i){array[i][j]=1;}else{array[i][j]=array[i-1][j-1]+array[i-1][j];}}}for(int i=0;i<n;i++){for(int j=0;j<=i;j++){System.out.printf("%5d",array[i][j]);}System.out.println();}}
}
  1. 输入处理

    • 读取用户输入的整数 n,表示要生成的杨辉三角的行数。

    • 创建一个大小为 n x n 的二维数组 array

  2. 填充杨辉三角

    • 使用双重循环遍历每一行和每一列。

    • 根据杨辉三角的性质,计算每个位置的值:

      • 如果是行的开头或结尾,直接赋值为 1

      • 否则,等于其左上方和右上方数字之和。

  3. 打印杨辉三角

    • 使用双重循环遍历数组,格式化输出每个数字。

    • 每行结束后换行。

3.小结

今天的分享到这里就结束了,喜欢的小伙伴点点赞点点关注,你的支持就是对我最大的鼓励,大家加油!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/34758.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用傅里叶变换测量声卡的频率失真

文章目录 一、说明二、关于声卡的技术详述三、实验代码获取四、结论 一、说明 假如我希望使用我的声卡来模拟软件无线电&#xff0c;利用声音而不是射频信号。我的声卡能胜任这项任务吗&#xff1f;本文将研究一种技术来找出答案。另外&#xff0c;需要了解音频技术的读者也可…

LeetCode 解题思路 18(Hot 100)

解题思路&#xff1a; 继承 LinkedHashMap&#xff1a; 内置双向链表&#xff0c;自动维护节点的插入顺序和访问顺序。LRU 淘汰逻辑&#xff1a; 覆盖 removeEldestEntry&#xff0c;当元素数量超过 capacity 时&#xff0c;移除最旧条目。removeEldestEntry 方法提供钩子&…

JS基础部分

引入方式 内部脚本 外部脚本 变量 使用let声明变量&#xff0c;弱类型&#xff0c;使用const声明常量 因为箭头函数中this指针有问题&#xff0c;会默认指向父级对象 DOM 文档对象模型&#xff0c;将标记语言的各个部分封装成对应的对象。js通过dom就能够对html进行操作 …

Linux与深入HTTP序列化和反序列化

深入HTTP序列化和反序列化 本篇介绍 在上一节已经完成了客户端和服务端基本的HTTP通信&#xff0c;但是前面的传递并没有完全体现出HTTP的序列化和反序列化&#xff0c;为了更好得理解其工作流程&#xff0c;在本节会以更加具体的方式分析到HTTP序列化和反序列化 本节会在介绍…

QT入门笔记2

目录 一、前言 二、串口助手实现 2.1、串口 2.1.1、可用串口信息-QSerialPortInfo 2.1.2、打开串口-QSerialPort 2.1.3、串口发送接收信息 2.2、定时器-QTimer 2.3、常用属性类型转换&#xff08;会更新&#xff09; 2.4、子控件组规则命名优化 一、前言 这个是学习Q…

DeepSeek(3):DeepSeek R1 提示词⼯程

1 提示词⼯程 5W1H&#xff08;What, Who, When, Where, Why, How&#xff09;是⼀种常⽤的信息收集和指令下达的⽅法。以下是根据这个⽅法为DeepSeek R1模型下指令的例⼦&#xff0c;以“学习⼤模型应⽤开发”为例&#xff1a; &#xff08;1&#xff09;What&#xff08;是什…

Linux入门 全面整理终端 Bash、Vim 基础命令速记

Linux入门 2025 超详细全面整理 Bash、Vim 基础命令速记 刚面对高级感满满的 终端窗口是不是有点懵&#xff1f;于是乎&#xff0c;这份手册就是为你准备的高效学习指南&#xff01;我把那些让人头大的系统设置、记不住的命令都整理成了对你更友好的格式&#xff0c;让你快速学…

RBA+minibatch的尝试

目录 还是咬着牙来写 RBA了 JAX JAX->TORCH torch tensor的变形 pytorch怎么把一个【3,3,5】的tensor变成【3,10,5】&#xff0c;多的用0填充 pytorch如何把shape【100】转成【100,1】 把torch shape【100,1】变成【100】 SQUEEZE grad_fn 不能两次反向传播 还…

Jupyter notebook的安装与使用

jupyter notebook的安装需要在已经安装配置好的conda环境下 win r 打开运行窗口 输入cmd回车 在cmd窗口中输入以下命令 conda install jupyter notebook安装完成后启动 jupyter notebook 也是在cmd窗口 输入 : jupyter notebook运行成功后第一次打开的时候需要选择一个浏览…

如何在Ubuntu上构建编译LLVM和ISPC,以及Ubuntu上ISPC的使用方法

之前一直在 Mac 上使用 ISPC&#xff0c;奈何核心/线程太少了。最近想在 Ubuntu 上搞搞&#xff0c;但是 snap 安装的 ISPC不知道为什么只能单核&#xff0c;很奇怪&#xff0c;就想着编译一下&#xff0c;需要 Clang 和 LLVM。但是 Ubuntu 很搞&#xff0c;他的很多软件版本是…

特殊的数字排序

0特殊的数字排序 - 蓝桥云课 问题描述 小明被挑选去参加一个ACM比赛。他的任务是解决一个很特别的问题&#xff1a;给定一个整数数组&#xff0c;但是只能通过交换任意两个数的方式来排序。听起来很简单对吗&#xff1f;但是这个问题的难点在于&#xff0c;只有某些数字是可以…

汽车感性负载-智能高边钳位能量计算

随着汽车电子技术的发展&#xff0c;新的电子电气架构下&#xff0c;越来越多的执行部件在车身出现&#xff0c;比如电磁阀、风机、水泵、油泵、雨刮继电器等常用的执行器&#xff0c; 它们一般都表现为感性特点。驱动这些负载的最简单和最常见的方法是将它们连接到高边侧开关(…

量化交易学习笔记02:双均线策略

双均线策略示例 个股&#xff1a;中国平安 回测日期&#xff1a;2022-5-1至2023-5-1 短均线&#xff1a;5天 长无线&#xff1a;10天 代码&#xff1a; def initialize(context):# 初始化此策略# 设置我们要操作的股票池, 这里我们只操作一支股票# """标的&qu…

利用余弦相似度在大量文章中找出抄袭的文章

我前面的2篇文章分别讲了如果利用余弦相似度来判断2篇文章的相似度&#xff0c;来确定文章是否存在抄袭&#xff0c;和余弦相似度的原理&#xff0c;即余弦相似度到底是怎么来判断文章的相似性高低的等等。这一篇再说下&#xff0c;对于文章字数多和大量文章时&#xff0c;如果…

在 Kaggle 中绘制中文乱码解决

在 Kaggle 中绘制中文时&#xff0c;需要设置 Matplotlib 的字体&#xff0c;否则中文会显示为乱码。可以使用 SimHei&#xff08;黑体&#xff09;或 Microsoft YaHei&#xff08;微软雅黑&#xff09;。 解决方案 使用 matplotlib 设置中文字体在 Kaggle 安装 SimHei 字体 …

在 Ubuntu 服务器上使用宝塔面板搭建博客

&#x1f4cc; 介绍 在本教程中&#xff0c;我们将介绍如何在 Ubuntu 服务器 上安装 宝塔面板&#xff0c;并使用 Nginx PHP MySQL 搭建一个博客&#xff08;如 WordPress&#xff09;。 主要步骤包括&#xff1a; 安装宝塔面板配置 Nginx PHP MySQL绑定域名与 SSL 证书…

Linux线程

1.线程概念 在一个程序里的一个执行路线就叫做线程(thread)&#xff0c;更准确定义&#xff1a;线程是一个进程内部的控制序列 进程至少有一个执行路线&#xff0c;线程在进程内部运行&#xff0c;本质是在进程地址空间内运行&#xff0c;在Linux系统中&#xff0c;CPU眼中&a…

【TI MSPM0】GPIO学习

一、文件样例查找 以GPIO软件轮询为例 下面的四个文件夹分别为不同开发环境提供支持 二、工程导入 1.点击file-点击import project 2.点击browse 3.找到对应的文件打开&#xff0c;选择 推荐使用ticlang,能够提供更加优化的效率 点击finish 三、工程学习 1.readme 文件 &a…

二叉树的基本操作与实现:C语言深度剖析

目录 代码整体框架 1. #define _CRT_SECURE_NO_WARNINGS 2. 头文件引入 3. typedef int BTtype; 4. 二叉树节点结构体定义 二叉树的创建 1. BuyNode 函数 2. CreatNode 函数 二叉树的遍历 前序遍历 中序遍历 后序遍历 二叉树属性的计算 节点个…

深入解析 Latent Diffusion Model(潜在扩散模型,LDMs)(代码实现)

深入解析 Latent Diffusion Model&#xff1a;从传统 Diffusion Model 到高效图像生成的进化 近年来&#xff0c;生成模型在图像合成领域取得了显著进展&#xff0c;其中 Diffusion Model&#xff08;扩散模型&#xff0c;DMs&#xff09;以其出色的生成质量和理论上的稳健性逐…