LeetCode 8. 字元串轉換整數 (atoi)

来源:https://www.cnblogs.com/izhoujie/archive/2020/04/03/12628914.html
-Advertisement-
Play Games

我的LeetCode:https://leetcode cn.com/u/ituring/ 我的LeetCode刷題源碼[GitHub]:https://github.com/izhoujie/Algorithmcii LeetCode 8. 字元串轉換整數 (atoi) 題目 請你來實現一個 at ...


我的LeetCode:https://leetcode-cn.com/u/ituring/

我的LeetCode刷題源碼[GitHub]:https://github.com/izhoujie/Algorithmcii

LeetCode 8. 字元串轉換整數 (atoi)

題目

請你來實現一個 atoi 函數,使其能將字元串轉換成整數。

首先,該函數會根據需要丟棄無用的開頭空格字元,直到尋找到第一個非空格的字元為止。接下來的轉化規則如下:

  • 如果第一個非空字元為正或者負號時,則將該符號與之後面儘可能多的連續數字字元組合起來,形成一個有符號整數。
  • 假如第一個非空字元是數字,則直接將其與之後連續的數字字元組合起來,形成一個整數。
  • 該字元串在有效的整數部分之後也可能會存在多餘的字元,那麼這些字元可以被忽略,它們對函數不應該造成影響。

註意:假如該字元串中的第一個非空格字元不是一個有效整數字元、字元串為空或字元串僅包含空白字元時,則你的函數不需要進行轉換,即無法進行有效轉換。

在任何情況下,若函數不能進行有效的轉換時,請返回 0 。

提示:

  • 本題中的空白字元只包括空格字元 ' ' 。
  • 假設我們的環境只能存儲 32 位大小的有符號整數,那麼其數值範圍為 [−2^31,  2^31 − 1]。如果數值超過這個範圍,請返回  INT_MAX (2^31 − 1) 或 INT_MIN (−2^31) 。

示例 1:

輸入: "42"
輸出: 42

示例 2:

輸入: "   -42"
輸出: -42
解釋: 第一個非空白字元為 '-', 它是一個負號。
     我們儘可能將負號與後面所有連續出現的數字組合起來,最後得到 -42 。

示例 3:

輸入: "4193 with words"
輸出: 4193
解釋: 轉換截止於數字 '3' ,因為它的下一個字元不為數字。

示例 4:

輸入: "words and 987"
輸出: 0
解釋: 第一個非空字元是 'w', 但它不是數字或正、負號。
     因此無法執行有效的轉換。

示例 5:

輸入: "-91283472332"
輸出: -2147483648
解釋: 數字 "-91283472332" 超過 32 位有符號整數範圍。 
     因此返回 INT_MIN (−231) 。

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/string-to-integer-atoi
著作權歸領扣網路所有。商業轉載請聯繫官方授權,非商業轉載請註明出處。

解題思路

atoi:ascii to integer
C和C#庫有自帶的atoi函數,但是Java並沒有,Java中與之相似的是Integer的 parseInt()系列方法,是雙參方法,多進位的轉化,可以看源碼瞭解下;

思路1-先左右去空白字元,然後校驗首字元為+和-的情況,最後逐個字元進行轉化即可,註意溢出判斷

步驟:

  1. 使用String的trim()方法對原字元串兩端的空白字元預處理;
  2. 判斷與處理後字元長度,必須大於1才能繼續,先取低一個字元對+和-情況處理;
  3. 依次逐個字元轉化,註意溢出判斷處理;

總結:atoi的轉換並不難,唯一需要註意的溢出判斷的邏輯

演算法源碼示例

package leetcode;

/**
 * @author ZhouJie
 * @date 2019年12月10日 下午6:13:52 
 * @Description:8. 字元串轉換整數 (atoi)
 *
 */
public class LeetCode_0008 {
	public static void main(String[] args) {
		Solution_0008 solution_0008 = new Solution_0008();
		System.out.println(solution_0008.myAtoi("2147483648"));
		Double.valueOf("53454.sdrf");
	}

}

class Solution_0008 {

	/**
	 * @author ZhouJie
	 * @date 2019年12月10日 下午7:00:52 
	 * @Description: TODO(方法簡述) 
	 * @return int 
	 * @UpdateUser-UpdateDate:[ZhouJie]-[2019年12月10日 下午7:00:52]  
	 * @UpdateRemark:1-思路:
	 * 					-先trim()左右去空並再次驗非空;
	 * 					-校驗首字元是+-的情況
	 * 					-逐個取字元轉化數字並校驗是否溢出
	 */
	public int myAtoi(String str) {
		if (str == null) {
			return 0;
		}
		// 去除左右空白字元,且去除後長度不能為0
		str = str.trim();
		int len = str.length();
		if (len < 1) {
			return 0;
		}
		int flag = 1;
		int i = 0;
		char c = str.charAt(0);
		// 首個字元為+或-的預處理,同時記錄符號
		if (c == '-' || c == '+') {
			i = 1;
			if (c == '-') {
				flag = -1;
			}
		}
		int rst = 0;
		int check = 0;
		// 逐個字元轉化,每次/10與上一次的值校驗用以判斷是否溢出
		for (; i < len; i++) {
			int num = str.charAt(i) - '0';
			if (num >= 0 && num <= 9) {
				rst = rst * 10 + num * flag;
				// 溢出校驗,若本次結果已溢出,那麼當前值/10必不等於上一次的值,利用溢出去校驗溢出,巧妙
				if (rst / 10 != check) {
					return flag == 1 ? ((1 << 31) - 1) : (-1 << 31);
				}
				check = rst;
			} else {
				return rst;
			}
		}
		return rst;
	}
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 字元串常見操作 索引 切片 字元串的常見操作 應用 判斷是否是小數 ...
  • 今天不灌水,直接上乾貨!希望下麵的講解,能與你產生一些共鳴。 1. 求長度各有千秋 你是否曾經在面試的時候,經常被問到:數組有沒有 length() 方法?字元串有沒有 length() 方法? 集合有沒有 length() 方法? 面對這個問題,那麼不得不吐槽一下,Java 中獲取長度的方式,設計 ...
  • byte Byte short Short int Integer long Long boolean Boolean char Character float Float double Double 基本數據類型對象包裝類最常見作用:用於基本數據類型和字元串類型之間做轉換。 基本數據類型轉成字元串 ...
  • 我的LeetCode:https://leetcode cn.com/u/ituring/ 我的LeetCode刷題源碼[GitHub]:https://github.com/izhoujie/Algorithmcii LeetCode 36. 有效的數獨 題目 判斷一個 9x9 的數獨是否有效。只 ...
  • 時間 java8以前使用的時間很多方法都已經廢棄了,而且不是線程安全的,java8提供了一系列的時間類,這些時間類都是線程安全的 LocalDate、LocalTime、LocalDateTime 這三個關於時間的類在使用上都類似 時間戳 Duration獲取時間間隔 Peroid獲取日期間隔 Te ...
  • 一、什麼是異常處理 異常處理從字面的意思來講就是一種發生在 java 程式中的錯誤並對其處理,但對程式員而言,異常的處理不單單的簡單去處理異常,就 ok 了,還有眾多的概念和使用異常的方式方法需要掌握 異常在 java 中分有三種: 1、編譯時異常(受檢異常) > 這種異常發生的概率很高; 2、運行 ...
  • 今天給大家分享五個開源的博客系統,可用於免費創建自己的博客,也有大量精美的模板使用,也就是說你不懂技術,用了這五個開源系統也能創建自己的博客,至於創建博客的好處,想必大家都知道,可用戶記錄生活,分享技術,也能鍛煉一下自己的文筆。 一.wordpress wordpress老牌博客系統,開源免費,有大 ...
  • 1、 Docker虛擬化鏡像製作實戰一 1)Docker commit可以實現容器提交為新的鏡像,提交的鏡像自動進入當前系統的鏡像列表(容器|鏡像內容是完整的); docker commit 7ec01484db55 centos7:v1 docker images 2)Docker export可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...