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
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...