每日5題Day3 - LeetCode 11 - 15

每一步向前都是向自己的夢想更近一步,堅持不懈,勇往直前!

第一題:11. 盛最多水的容器 - 力扣(LeetCode)

class Solution {public int maxArea(int[] height) {//這道題比較特殊,因為兩邊是任意選的,//所以中間可以出現比兩邊高的情況,實際就是雙指針求一個矩形的面積//寬度為左右邊界的差值,高度為左右高度的較小值,所以我們進行模擬int l = 0, r = height.length - 1, maxres = 0;while(l < r){if(maxres < (r - l) * Math.min(height[l], height[r])){maxres = (r - l) * Math.min(height[l], height[r]);}//不斷挪動邊界,因為寬度是在不斷縮小的,那么如果我們挪動較高的那邊,//得到的結果一定比以前小,所以挪動較低的那一邊if(height[l] <= height[r]){l++;}else{r--;}}return maxres;}
}

第二題:12. 整數轉羅馬數字 - 力扣(LeetCode)

class Solution {// 數值對應的羅馬數字int[] values = {1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1};// 羅馬數字String[] symbols = {"M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"};// 將整數轉換為羅馬數字public String intToRoman(int num) {StringBuilder sb = new StringBuilder();// 遍歷數值對應的數組for (int i = 0; i < values.length; ++i) {int value = values[i];String symbol = symbols[i];// 當 num 大于等于當前數值時,循環減去該數值,并將對應的羅馬數字追加到結果中while (num >= value) {num -= value;sb.append(symbol);}// 如果 num 等于 0,表示已經轉換完成,直接跳出循環if (num == 0) {break;}}// 返回轉換后的羅馬數字字符串return sb.toString();}
}

第三題:13. 羅馬數字轉整數 - 力扣(LeetCode)

class Solution {// 將羅馬數字轉換為整數public int romanToInt(String s) {int res = 0; // 結果變量,用于存儲轉換后的整數值int preNum = getValue(s.charAt(0)); // 前一個羅馬數字對應的整數值// 遍歷字符串 s 中的每個字符for(int i = 1; i < s.length(); i++){int num = getValue(s.charAt(i)); // 當前字符對應的整數值// 如果前一個字符對應的整數值小于當前字符對應的整數值,則將結果減去前一個字符對應的整數值if(preNum < num){res -= preNum;}else{ // 否則,將結果加上前一個字符對應的整數值res += preNum;}preNum = num; // 更新前一個字符對應的整數值為當前字符對應的整數值}res += preNum; // 加上最后一個字符對應的整數值return res; // 返回最終的整數值}// 獲取字符對應的整數值private int getValue(char ch){switch(ch) {case 'I' : return 1;case 'V' : return 5;case 'X': return 10;case 'L': return 50;case 'C': return 100;case 'D': return 500;case 'M': return 1000;default: return 0;}}
}

第四題:14. 最長公共前綴 - 力扣(LeetCode)

import java.util.Arrays;
import java.util.Comparator;class Solution {// 尋找字符串數組中的最長公共前綴public String longestCommonPrefix(String[] strs) {// 根據字符串長度對數組進行排序Arrays.sort(strs, new Comparator<String>(){@Overridepublic int compare(String o1, String o2){return o1.length() - o2.length();}});// 獲取最短字符串的長度int maxlen = strs[0].length();int res = 0, index = 0; // res: 公共前綴長度,index: 當前比較的字符索引// 遍歷最短字符串的長度while(index < maxlen){char tmpch = '.'; // 臨時變量,用于存儲當前比較的字符,默認為'.'表示未初始化// 遍歷字符串數組中的每個字符串for(String st : strs){// 如果臨時字符是'.',則將當前字符作為臨時字符if(tmpch == '.'){tmpch = st.charAt(index);}// 否則,如果當前字符與臨時字符不相等,則返回公共前綴(如果 res 不為 0),否則返回空字符串else{if(st.charAt(index) != tmpch){return res != 0 ? strs[0].substring(0, res) : "";}}}index++; // 移動到下一個字符位置res++; // 更新公共前綴長度}// 返回最長公共前綴return strs[0].substring(0, res);}
}

?第五題:15. 三數之和 - 力扣(LeetCode)

class Solution {// 定義一個方法threeSum,接收一個整數數組nums作為參數,返回所有和為0的三元組public List<List<Integer>> threeSum(int[] nums) {// 初始化結果列表List<List<Integer>> res = new ArrayList<>();// 對數組進行排序,以便于后續的雙指針操作Arrays.sort(nums);// 遍歷數組,使用i作為第一個數字for(int i = 0; i < nums.length - 2; i++) {// 跳過相同的元素,避免重復的三元組if(i > 0 && nums[i] == nums[i - 1]) {continue;}// 初始化左右指針int j = i + 1, k = nums.length - 1;// 使用while循環進行雙指針操作,尋找和為0的三元組while(j < k) {// 計算當前三元組的和int cursum = nums[i] + nums[j] + nums[k];// 如果當前和小于0,說明需要增大和,因此移動左指針jif(cursum < 0) {j++;} else if(cursum > 0) {// 如果當前和大于0,說明需要減小和,因此移動右指針kk--;} else {// 如果當前和為0,找到了一個三元組res.add(Arrays.asList(nums[i], nums[j], nums[k]));// 跳過相同的元素,避免重復的三元組while(j < k && nums[j] == nums[j + 1]) {j++;}while(j < k && nums[k] == nums[k - 1]) {k--;}// 移動指針繼續尋找下一個可能的三元組j++;k--;}}}// 返回所有找到的三元組return res;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/12984.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/12984.shtml
英文地址,請注明出處:http://en.pswp.cn/web/12984.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

04、SpringBoot 源碼分析 - SpringApplication啟動流程四

SpringBoot 源碼分析 - SpringApplication啟動流程四 初始化基本流程SimpleApplicationEventMulticaster的multicastEvent廣播事件resolveDefaultEventType獲取ResolvableType實例ResolvableType的forInstance創建ResolvableType實例 開始廣播AbstractApplicationEventMulticas…

脈沖水路清洗機,全自動脈沖技術清除管道堵塞

邦注脈沖水路清洗機是一種高效的清洗設備&#xff0c;它利用全自動脈沖技術來清除管道內的堵塞和污垢。以下是對該設備的一些詳細描述&#xff1a; 全自動脈沖技術&#xff1a;脈沖水路清洗機采用了全自動脈沖技術&#xff0c;這是一種先進的清洗方法。該技術通過產生高強度的…

window10下安裝ubuntu系統以及docker使用

window10下安裝ubuntu系統以及docker使用 1. 啟用適用于Linux的Windwos子系統2.下載Linux內核更新包3.將 WSL 2 設置為默認版本4.安裝Ubuntu<br />直接去Microsoft store里面直接搜索Ubuntu進行安裝。5.可能出現的問題1.win10啟動ubuntu報錯 參考的對象類型不支持嘗試的操…

Linux|基礎環境開發工具使用(1)

目錄 Linux 軟件包管理器 yum 什么是軟件包 關于 rzsz 注意事項 查看軟件包 如何安裝軟件 如何卸載軟件 Linux編輯器-vim介紹 vi與vim的相同點 vi與vim區別 Linux 軟件包管理器 yum 什么是軟件包 在Linux下安裝軟件, 一個通常的辦法是下載到程序的源代碼, 并進行編譯…

【WebGPU】WebGPU 中的反應擴散計算著色器

在本教程中&#xff0c;我們將使用 WebGPU 技術中的計算著色器實現圖像效果。更多精彩內容盡在數字孿生平臺。 程序結構 主要構建兩個 WebGPU 管道&#xff1a; 運行反應擴散算法多次迭代的計算管道&#xff08;js/rd-compute.js 和 js/shader/rd-compute-shader.js&#xff…

react 渲染引擎經歷了那些迭代

React 渲染引擎經歷了多個迭代&#xff0c;主要集中在改進 Virtual DOM 的實現和優化渲染性能方面。以下是一些 React 渲染引擎的主要迭代&#xff1a; React Fiber 架構&#xff1a;React 16 引入了 Fiber 架構&#xff0c;這是一個重新實現的渲染引夠更好地支持異步渲染。 S…

script標簽以及defer和async屬性

1. <script>標簽 將JavaScript代碼嵌入到HTML中主要方式是使用<script>元素。 使用<script>的方式有兩種&#xff1a; &#xff08;1&#xff09;直接在網頁中嵌入JavaScript代碼&#xff1a; <script>function sayHi() {console.log("Hi"…

Leetcode—2244. 完成所有任務需要的最少輪數【中等】

2024每日刷題&#xff08;136&#xff09; Leetcode—2244. 完成所有任務需要的最少輪數 實現代碼 class Solution { public:int minimumRounds(vector<int>& tasks) {unordered_map<int, int> map;for(int task: tasks) {map[task];}int ans 0;// freq 1 …

【前端】CSS基礎(3)

文章目錄 前言1. CSS常用元素屬性1.1 字體屬性1.1.1 字體1.1.2 字體大小1.1.3 字體顏色1.1.4 字體粗細1.1.5 文字樣式 前言 這篇博客僅僅是對CSS的基本結構進行了一些說明&#xff0c;關于CSS的更多講解以及HTML、Javascript部分的講解可以關注一下下面的專欄&#xff0c;會持續…

c++父類指針指向子類

有一個常見的c題&#xff0c;就是父類和子類的構造函數和析構函數分別調用順序&#xff1a; 父類構造函數子類構造函數子類析構函數父類析構函數 以及父類中的函數在子類中重新實現后&#xff0c;父類指針指向子類后&#xff0c;該指針調用的函數是父類中的還是子類中的&…

震撼發布!GPT-4o 上線!

5 月 14日凌晨一點&#xff0c;OpenAI 發布了 GPT-4o&#xff01; 新模型的功能簡單概括就是&#xff1a;更快、更智能、更像人類。 秉承著持續更新的態度&#xff0c;Hulu AI 快速接入 GPT-4o 啦&#xff01; 繼 5 月份上線 Suno 之后&#xff0c;這次是 Hulu AI 的又一重大…

vue3專欄項目 -- 六、上傳組件(上)

1、上傳組件需求分析 我們還需要新建和展示文章&#xff0c;新建文章自然是發送post請求&#xff0c;同時在post中自帶對應的數據&#xff0c;展示文章就是根據id取出已有的數據并且展示出來。 這里有一個難點就是上傳組件&#xff0c;上傳文件是App應用中最基本的需求&#…

Socks5:網絡世界的隱形斗篷

在數字化時代&#xff0c;網絡隱私和安全已成為人們日益關注的話題。Socks5&#xff0c;作為一種代理協議&#xff0c;為用戶在網絡世界中的匿名性提供了強有力的支持。本文將從Socks5的多個方面&#xff0c;深入探討這一技術如何成為網絡世界的“隱形斗篷”。 一、Socks5的基本…

linux基礎指令講解(ls、pwd、cd、touch、mkdir)

&#x1fa90;&#x1fa90;&#x1fa90;歡迎來到程序員餐廳&#x1f4ab;&#x1f4ab;&#x1f4ab; 主廚&#xff1a;邪王真眼 主廚的主頁&#xff1a;Chef‘s blog 所屬專欄&#xff1a;c大冒險 總有光環在隕落&#xff0c;總有新星在閃爍 這個是我們今天要用到的初始…

P8805 [藍橋杯 2022 國 B] 機房

P8805 [藍橋杯 2022 國 B] 機房 分析 是一道lca題目&#xff0c;可以直接套模板 前綴和處理點權 具體思路&#xff1a; 1.n臺電腦用n-1條網線相連&#xff0c;任意兩個節點之間有且僅有一條路徑&#xff08;拆分成各自到公共祖先節點的路徑——lca&#xff09;&#xff1b;…

Delphi7:SuperObject 的示例

SuperObject 不是一個 Delphi 7 自帶或官方的庫&#xff0c;但可能是指一些開源的 JSON 解析庫&#xff0c;比如 superobject 或 dwscript 中的 SuperObject。這些庫通常用于解析和生成 JSON 數據。 以下是一個基于假設的 SuperObject 用法概述&#xff0c;因為不同的庫可能有…

波搜索算法(WSA)-2024年SCI新算法-公式原理詳解與性能測評 Matlab代碼免費獲取

? 聲明&#xff1a;文章是從本人公眾號中復制而來&#xff0c;因此&#xff0c;想最新最快了解各類智能優化算法及其改進的朋友&#xff0c;可關注我的公眾號&#xff1a;強盛機器學習&#xff0c;不定期會有很多免費代碼分享~ 目錄 原理簡介 一、初始化階段 二、全…

我與C++的愛戀:string類的常見接口函數

? ? &#x1f525;個人主頁&#xff1a;guoguoqiang. &#x1f525;專欄&#xff1a;我與C的愛戀 朋友們大家好啊&#xff0c;本節我們來到STL內容的第一部分&#xff1a;string類接口函數的介紹 ? ? 1.string類的認識 給大家分享一個c文檔 https://legacy.cplusplus.…

Weblogic 管理控制臺未授權遠程命令執行漏洞(CVE-2020-14882,CVE-2020-14883)

1 漏洞概述 Weblogic Pre-Auth Remote Command Execution 漏洞&#xff08;CVE-2020-14882, CVE-2020-14883&#xff09;是針對 Oracle WebLogic Server 的兩個安全漏洞。CVE-2020-14882 允許遠程用戶繞過管理員控制臺組件中的身份驗證&#xff0c;而 CVE-2020-14883 則允許經…

Python3 筆記:Python的函數

函數是編寫好的&#xff0c;可重復調用的&#xff0c;用來實現某一功能的一段代碼。 也可以理解為做某事的方法和步驟。第一次做的時候寫好了方法&#xff0c;下次同類型的事直接拿來就用。 Python 內部有很多功能強大的內置函數供我們使用&#xff0c;除此之外&#xff0c;你…