leetcode算法题记录:

14、最长公共前缀

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""

示例 1:

输入:strs = ["flower","flow","flight"]
输出:"fl"

示例 2:

输入:strs = ["dog","racecar","car"]
输出:""
解释:输入不存在公共前缀。

class Solution {public String longestCommonPrefix(String[] strs) {if(strs==null||strs.length==0){return "";}//length:数组,length()字符串长度StringBuilder sb=new StringBuilder();for(int i=0;i<strs[0].length();i++){
char c=strs[0].charAt(i);
for(int j=1;j<strs.length;j++){if(i>=strs[j].length()||strs[j].charAt(i)!=c){return sb.toString();}
}sb.append(c);//对比成功就添加进去}return sb.toString();}
}

先判断数组是否为初始化或者看他长度是否为零,如果这两个条件当中满足一个的话,就直接返回空字符串。然后再定义一个stringBuilder(

常用方法

  • append(): 添加内容到字符串末尾

  • insert(): 在指定位置插入内容

  • delete(): 删除指定范围内的字符

  • reverse(): 反转字符串

  • toString(): 将 StringBuilder 转换为 String

将数组中的前一个和后一个字符串抠出来,然后再将第一个作为确定的对比对象(就是后面的字符串都要和第一个比较一次),然后再把两个字符串中的每个字符抠出来对比,相同就append,不同就直接转为字符串输出。

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

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

相关文章

HarmonyOS 应用开发深入浅出:基于 Stage 模型与 ArkUI 的声明式开发实践

好的&#xff0c;请看这篇关于 HarmonyOS 应用开发中 Stage 模型与 ArkUI 声明式开发实践的技术文章。 HarmonyOS 应用开发深入浅出&#xff1a;基于 Stage 模型与 ArkUI 的声明式开发实践 引言 随着 HarmonyOS 的不断发展&#xff0c;其应用开发范式也经历了重大的演进。从…

web服务解析案例

题目 模拟一个基于 DNS&#xff08;域名系统&#xff09;和 Nginx 的 Web 服务架构。 整体是模拟从用户输入域名&#xff0c;经 DNS 解析找到 Web 服务器&#xff0c;再由 Web 服务器&#xff08;Nginx&#xff09;提供内容的完整 Web 服务流程。 主机规划主机名ip地址软件说明…

揭示电解液与界面奥秘,理论计算赋能水系电池创新

揭示电解液与界面奥秘&#xff0c;理论计算赋能水系电池创新随着全球对高安全、低成本储能需求的激增&#xff0c;水系电池成为了下一代电池技术的重要候选者。然而&#xff0c;其性能瓶颈&#xff0c;如循环寿命、能量密度等&#xff0c;深深根植于复杂的电解液化学和电极-电解…

xv6实验:Ubuntu2004 WSL2实验环境配置(包括git clone网络问题解决方法)

基本配置参考MIT6.S081 Ubuntu22.04 WSL2实验环境配置,wsl安装配置参考本栏的另一篇文章WSL2&#xff08;ubuntu20.04&#xff09;vscode联合开发(附迁移方法) 如执行: git clone git://github.com/mit-pdos/xv6-riscv.git出现错误,或者无法clone情况,可以挂一个代理,然后按如…

reversed()方法

在 Python 中&#xff0c;reversed() 是一个内置函数&#xff0c;用于返回一个反向迭代器对象。这个函数可以处理多种序列类型的数据&#xff0c;如列表、元组、字符串、范围对象等&#xff0c;通过它可以方便地实现序列元素的反向遍历。下面从基本语法、适用对象、使用示例等方…

根据文本区域`textarea`的内容调整大小`field-sizing:content`

field-sizing:content 新属性&#xff0c;可以让 文本域textarea 根据输入的内容自动调整大小&#xff0c; 无需使用javascript See the Pen 根据文本区域textarea的内容调整大小field-sizing:content by liu874396180 ( liu874396180) on CodePen.

Python3练习题

上一节中全面讲解了基础知识&#xff0c;为了巩固知识点&#xff0c;当然最好的方法就是练习了。 练习 1&#xff1a;变量类型转换与算术运算 需求&#xff1a;接收用户输入的两个数字&#xff08;可能是整数或字符串格式&#xff09;&#xff0c;转换为浮点数后计算 “幂运算、…

Motioncam Color S + 蓝激光:3D 视觉革新,重塑工业与科研应用新格局

在工业自动化、科研探索及智能检测等前沿领域&#xff0c;对物体进行高精度、高速度且稳定可靠的三维成像&#xff0c;始终是推动技术进步与效率提升的关键诉求。过往的 3D 成像设备&#xff0c;常因精度欠佳、对复杂材质适应性差、难以应对动态场景等局限&#xff0c;在实际应…

用html5写一个第一视角的摩托车开车游戏,画上摩托车把手,把手两侧放上可操控方向的按钮,再加上,前进和减速的按钮

<!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>第一视角摩托车</title><style>html…

SpringMVC 系列博客(一):基础概念与注解开发入门

目录 一、引言 二、MVC 模式&#xff1a;SpringMVC 的设计基石 2.1 MVC 三大组件 2.2 主流 MVC 框架对比 2.3 MVC 模式的核心优势 三、SpringMVC 框架&#xff1a;是什么&#xff1f;为什么学&#xff1f; 3.1 什么是 SpringMVC&#xff1f; 3.2 为什么要学 SpringMVC&a…

Java 字符串操作教程:三个任务完整复现与解析

这次是完成一些小任务来试试身手&#xff0c;免得生疏&#xff1a; 编写程序&#xff0c;使用charAt和length方法&#xff0c;将字符串"HelloWorld"拆分为"Hello"和"World"两个子串并输出。 设计一个方法&#xff0c;利用indexOf和lastlndexOf&a…

向量技术研究报告:从数学基础到AI革命的支柱

1. 向量的数学本质与历史演变 1.1 核心定义与数学表示 向量是同时具有大小&#xff08;Magnitude&#xff09;和方向&#xff08;Direction&#xff09;的量&#xff0c;在数学上被严格定义为向量空间中的元素。与仅有大小的标量&#xff08;Scalar&#xff09;不同&#xff0c…

Qt QHorizontalStackedBarSeries详解

1、概述QHorizontalStackedBarSeries 是 Qt Charts 模块中的一个类&#xff0c;用于创建水平堆叠条形图。它继承自 QAbstractBarSeries 类&#xff0c;允许将多个数据系列堆叠在一起显示&#xff0c;每个条形由多个部分组成&#xff0c;这些部分共同构成一个完整的条形&#xf…

《股票智能查询与投资决策辅助应用项目方案》

前引&#xff1a;本股票智能查询与投资决策辅助应用通过整合多源金融数据&#xff0c;运用量化分析 机器学习技术&#xff0c;为普通投资者提供全方位股票信息服务和个性化投资建议。系统不仅解决了传统工具 “数据分散、分析复杂” 的问题&#xff0c;更通过人性化交互和直观…

从零开始构建Kubernetes Operator:一个完整的深度学习训练任务管理方案

从零开始构建Kubernetes Operator&#xff1a;一个完整的深度学习训练任务管理方案一、引言二、为什么需要Operator&#xff1f;1. Controller vs Operator&#xff1a;本质区别2. 有状态服务 vs 无状态服务的挑战三、项目架构设计3.1整体架构图3.2核心组件4.核心实现解析1. CR…

第二十二篇|新世界语学院教育数据深度解析:学制函数、能力矩阵与升学图谱

第二十二篇&#xff5c;新世界语学院教育数据深度解析&#xff1a;学制函数、能力矩阵与升学图谱 系列主题&#xff1a;500所日本语言学校结构数据工程 关键词&#xff1a;新世界语学院、东京新宿、学制函数建模、JLPT能力矩阵、升学网络、教育数据工程 一、合规与法人建模&…

Java开发工具选择指南:Eclipse、NetBeans与IntelliJ IDEA对比

在Java开发的世界里&#xff0c;选择合适的开发工具就如同挑选一把称手的禅杖&#xff0c;能助你在代码修行的路上更加得心应手。本文将为Java开发者提供一份实用的IDE选择指南&#xff0c;从功能、适用人群、性能等方面深入解析几款主流的Java开发工具&#xff0c;帮助你找到最…

iOS App 内存泄漏与性能调优实战 如何排查内存问题、优化CPU与GPU性能、降低耗电并提升流畅度(uni-app iOS开发优化指南)

在 iOS 应用开发中&#xff0c;内存泄漏 是最常见且最难排查的性能问题之一。 它会导致应用 运行越来越卡、占用内存过高、频繁崩溃&#xff0c;甚至严重消耗电池。 尤其在 uni-app 跨平台开发 中&#xff0c;JS 层和原生层的混合调用更容易隐藏内存问题&#xff1a; 对象未释放…

从源代码开始构建、部署和管理应用程序

1.创建项目目录并准备应用程序的代码及其依赖1.创建项目目录&#xff0c;并将当前目录切换到该目录[roothost1 ~]# mkdir python-web && cd python-web2.创建 app.py 文件并添加以下代码[roothost1 python-web]# vi app.py [roothost1 python-web]# cat app.py import …

Flutter-[2]第一个应用

摘要 根据官方文档搭配好环境&#xff0c;使用vscode创建完应用后&#xff0c;会遇到以下问题 设备无法选择打开了lib\main.dart右上角也没有运行按钮 环境 Windows11Flutter 3.35.4 必要设置 1. 查看是否开启Windows桌面应用开发flutter config --list输出如下: All Settings:…