国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題

這篇具有很好參考價值的文章主要介紹了模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

各位朋友們,大家好啊!今天我為大家分享的知識是如何模擬實現(xiàn)atoi函數(shù)。相信大家如果能夠理解這個知識,對大家以后的刷題是有幫助的。

什么是atoi函數(shù)(atoi函數(shù)的作用)

我們要想實現(xiàn)某個函數(shù),我們肯定要先知道這個函數(shù)的作用是什么,然后我們再根據(jù)它的作用來自己實現(xiàn)。我們先來看看stoi函數(shù)在庫函數(shù)中是怎么樣的吧。

int atoi (const char * str);

這函數(shù)的參數(shù)只有一個字符串的地址,它的返回類型是一個整型類型。
模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題
這句話的意思是:
該函數(shù)首先根據(jù)需要丟棄盡可能多的空格字符(如在 isspace 中),直到找到第一個非空格字符。然后,從此字符開始,取一個可選的首字母加號或減號,后跟盡可能多的 10 進制數(shù)字,并將它們解釋為數(shù)值。

字符串可以在構成整數(shù)的字符之后包含其他字符,這些字符將被忽略,并且對此函數(shù)的行為沒有影響。

如果 str 中的第一個非空格字符序列不是有效的整數(shù),或者由于 str 為空或僅包含空格字符而不存在此類序列,則不執(zhí)行轉換并返回零。

先直接使用庫函數(shù)看看這個函數(shù)是什么作用

我們要想使用atoi這個函數(shù),我們需要引用#include這個頭文件。

都是正整數(shù)字符的字符串

#include<stdio.h>
#include<stdlib.h>

int main()
{
	char* arr = "1234";   //我們先舉一個正整數(shù)的例子
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題

含有負號的整數(shù)字符的字符串

#include<stdio.h>
#include<stdlib.h>

int main()
{
	char* arr = "-1234";   //負整數(shù)
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題

含有非數(shù)字字符的字符串,且非數(shù)字字符都在一起

#include<stdio.h>
#include<stdlib.h>

int main()
{
	char* arr = "-1234#abd";
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題

數(shù)字字符跟非數(shù)字字符交叉出現(xiàn)

#include<stdio.h>
#include<stdlib.h>

int main()
{
	char* arr = "-1234a23cd";  //數(shù)字跟字母交叉出現(xiàn)
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題
通過這幾種代碼,我們大概可以知道,atoi函數(shù)在遇到非數(shù)字字符就會停止讀取了。

模擬實現(xiàn)atoi函數(shù)

我們實現(xiàn)atoi函數(shù)主要針對這些問題:

  1. 空指針。當傳入的參數(shù)是NULL時,我們應該對其做出判斷,以防出現(xiàn)非法訪問。
  2. 空字符串。當傳入的字符串為空時,我們就返回0
      • .當傳入的字符串中第一個字符時’+‘或者’-'的時候,我們需要判斷這個字符串的正負性。
  3. 非數(shù)字字符。當字符串中出現(xiàn)了非數(shù)字字符的時候,我們需要直接停止當前函數(shù)并返回已經(jīng)轉換完成的數(shù)字。
  4. 越界。因為在庫函數(shù)中,atoi函數(shù)返回的是int類型,但是當我們傳入的字符串長度很長時,那么這個字符串在轉換為整形的時候,可能會出現(xiàn)超過int所表示的范圍的時候。這時候我們就可以停止當前函數(shù)并返回已經(jīng)轉換完成的整數(shù)。下面就是代碼實現(xiàn)。
#include<stdio.h>
#include<limits.h>  //int類型的取值范圍
#include<ctype.h>   //判斷是否為數(shù)字字符
#include<assert.h>  //判斷傳入的字符串是否為NULL

//我們定義一個枚舉來判斷最終返回的結果是否是正常讀取結束的
enum S
{
	VALID,
	INVALID
};

enum S s = INVALID;

int my_atoi(char* str)
{
	assert(str);
	if (*str == '\0')
	{
		return 0;
	}
	//這個flag是來決定你最終的整數(shù)的正負性
	int flag = 1;
	if (*str == '-')
	{
		flag = -1;
		str++;
	}
	else if (*str == '+')
	{
		flag = 1;
		str++;
	}
	long long ret = 0;
	while (*str != '\0')
	{
		if (isdigit(*str))
		{
			ret = ret * 10 + flag * (*str - '0');
			if (ret > INT_MAX || ret < INT_MIN)
			{
				return (int)ret;
			}
		}
		else
		{
			return (int)ret;
		}
		str++;
	}
	if (*str == '\0')
	{
		s = VALID;
	}
	return (int)ret;
}

int main()
{
	char* arr = "-1234a5s3gd";
	int ret = my_atoi(arr);
	if (s == INVALID)
	{
		printf("坐標非法:%d\n", ret);
	}
	else
	{
		printf("合法轉換:%d\n", ret);
	}

	return 0;
}

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題

leedcode相關題目

leetcode之字符串轉換整數(shù) (atoi)

題目要求

請你來實現(xiàn)一個 myAtoi(string s) 函數(shù),使其能將字符串轉換成一個 32 位有符號整數(shù)(類似 C/C++ 中的 atoi 函數(shù))。

函數(shù) myAtoi(string s) 的算法如下:

讀入字符串并丟棄無用的前導空格
檢查下一個字符(假設還未到字符末尾)為正還是負號,讀取該字符(如果有)。 確定最終結果是負數(shù)還是正數(shù)。 如果兩者都不存在,則假定結果為正。
讀入下一個字符,直到到達下一個非數(shù)字字符或到達輸入的結尾。字符串的其余部分將被忽略。
將前面步驟讀入的這些數(shù)字轉換為整數(shù)(即,“123” -> 123, “0032” -> 32)。如果沒有讀入數(shù)字,則整數(shù)為 0 。必要時更改符號(從步驟 2 開始)。
如果整數(shù)數(shù)超過 32 位有符號整數(shù)范圍 [?231, 231 ? 1] ,需要截斷這個整數(shù),使其保持在這個范圍內。具體來說,小于 ?231 的整數(shù)應該被固定為 ?231 ,大于 231 ? 1 的整數(shù)應該被固定為 231 ? 1 。
返回整數(shù)作為最終結果。

注意:

本題中的空白字符只包括空格字符 ’ ’ 。
除前導空格或數(shù)字后的其余字符串外,請勿忽略 任何其他字符。

代碼實現(xiàn)

int myAtoi(char * s){
	assert(s);
	//判斷是否為空字符串
	if (*s == '\0')
	{
		return 0;
	}
	//因為他給的字符串可能開始就是空格,所以我們需要跳過這些空格
	while(*s == ' ')
	{
		s++;
	}
	int flag = 1;
	if (*s == '-')
	{
		flag = -1;
		s++;
	}
	else if (*s == '+')
	{
		flag = 1;
		s++;
	}
	long long ret = 0;
	while (*s != '\0')
	{
		if (isdigit(*s))
		{
			ret = ret * 10 + flag * (*s - '0');
			if (ret >= INT_MAX)
			{
	//這里注意題目的要求,如果超過int的范圍,如果大于2^31-1,就返回2^31-1
				return INT_MAX;
			}
			else if(ret <= INT_MIN)
			{
			//小于-2^31就返回-2^31
				return INT_MIN;
			}
		}
		else
		{
			return (int)ret;
		}
		s++;
	}
	return (int)ret;
}

模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題

小結

大家可以自己去寫寫這道題,鞏固下這個知識。那么到這里,我的這次分享就結束了,如果有錯誤,歡迎大家指出來,如果覺得博主寫的不錯記得給個贊哦。非常感謝?。。?span toymoban-style="hidden">文章來源地址http://www.zghlxwxcb.cn/news/detail-418427.html

到了這里,關于模擬實現(xiàn)atoi函數(shù)(將數(shù)字字符串轉換為整型)附加leetcode練習題的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉載,請注明出處: 如若內容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • 字符函數(shù)和字符串函數(shù)的模擬實現(xiàn)

    字符函數(shù)和字符串函數(shù)的模擬實現(xiàn)

    求字符串長度 strlen ?長度不受限制的字符串函數(shù) strcpy strcmp strcat 長度受限制的字符串函數(shù) strnlen strncmp strncpy strncat 字符串查找 strstr strtok 錯誤信息報告 strerror 內存操作函數(shù) memcpy memmove memset memcmp ?首先我們來看strlen 字符串是以‘\\0’為結束標志,strlen函數(shù)返回的是‘\\0’出現(xiàn)

    2024年02月13日
    瀏覽(23)
  • 字符函數(shù)和字符串函數(shù)解析及模擬實現(xiàn)

    字符函數(shù)和字符串函數(shù)解析及模擬實現(xiàn)

    字符串以’\\0’作為結束標志,strlen函數(shù)返回的是在字符串中’\\0’前面出現(xiàn)過的字符個數(shù)(不包括’\\0’)。 參數(shù)指向的字符串必須以’\\0’結束。 注意函數(shù)的返回值位size_t, 是無符號的 。 Copies the C string pointed by source into the array pointed by destination, including the terminating null c

    2024年02月16日
    瀏覽(19)
  • 高階C語言|字符函數(shù)和字符串函數(shù)--函數(shù)的模擬實現(xiàn)

    高階C語言|字符函數(shù)和字符串函數(shù)--函數(shù)的模擬實現(xiàn)

    C語言中對字符和字符串的處理很是頻繁,但是C語言本身是沒有字符串類型的,字符串通常放在 常量字符串 中或者 字符數(shù)組 中。 字符串常量 適用于那些對它不做修改的字符串函數(shù) size_t代表strlen函數(shù)返回的是一個無符號整形,str指向的是字符串,接收字符串的地址 字符串已

    2024年02月16日
    瀏覽(23)
  • 字符和字符串的庫函數(shù)模擬與實現(xiàn)

    字符和字符串的庫函數(shù)模擬與實現(xiàn)

    前言: 相信大家平常在寫代碼的時候,用代碼解決實際問題時苦于某種功能的實現(xiàn),而望而止步,這個時候庫函數(shù)的好處就體現(xiàn)出來了,當然個人代碼編寫能力強的可以自己創(chuàng)建一個函數(shù),不過相當于庫函數(shù)來說卻是浪費了一點時間,庫函數(shù)的準確性和有效性對我們的好處就

    2024年02月10日
    瀏覽(23)
  • C/C++字符函數(shù)和字符串函數(shù)模擬實現(xiàn)與詳解————長度不受限制的字符串函數(shù)

    C/C++字符函數(shù)和字符串函數(shù)模擬實現(xiàn)與詳解————長度不受限制的字符串函數(shù)

    個人主頁:點我進入主頁 專欄分類:C語言初階? ? ??C語言程序設計————KTV? ? ? ?C語言小游戲? ? ?C語言進階 C語言刷題 歡迎大家點贊,評論,收藏。 一起努力,一起奔赴大廠。 目錄 ? 1.前言? 2strlen函數(shù)? ?3.strcpy函數(shù) 4.strcat函數(shù) 5.strcmp函數(shù) ? ????????對于字符串

    2024年02月07日
    瀏覽(17)
  • 深入探索字符串函數(shù)與模擬實現(xiàn)

    深入探索字符串函數(shù)與模擬實現(xiàn)

    ? 目錄 ?前言: 一.常見函數(shù)的介紹與模擬實現(xiàn) 一.strlen函數(shù) 1.1? strlen函數(shù)的介紹 1.2? strlen的模擬實現(xiàn)(三種方式實現(xiàn)) 第一種:計數(shù)器的方式 第二種:遞歸的方式 第三種:指針-指針的方式 二.strcpy函數(shù)與strncpy函數(shù) 2.1? strcpy函數(shù)的介紹? 2.2strncpy函數(shù)的介紹? 2.3? strcpy的模

    2024年02月16日
    瀏覽(21)
  • 【C語言】字符函數(shù)和字符串函數(shù)的詳細教學和模擬實現(xiàn)

    【C語言】字符函數(shù)和字符串函數(shù)的詳細教學和模擬實現(xiàn)

    ??write in front?? ??大家好,我是gugugu。希望你看完之后,能對你有所幫助,不足請指正!共同學習交流?? ??本文由 gugugu 原創(chuàng) CSDN首發(fā)?? 如需轉載還請通知? ??個人主頁:gugugu—精品博客 ??歡迎各位→點贊?? + 收藏?? + 留言??? ??系列專欄:gugugu的精品博客 ??

    2024年02月08日
    瀏覽(20)
  • 【C語言】字符函數(shù)和字符串函數(shù)(一)—>庫函數(shù)的介紹與模擬實現(xiàn)

    【C語言】字符函數(shù)和字符串函數(shù)(一)—>庫函數(shù)的介紹與模擬實現(xiàn)

    目錄 前言: 一、函數(shù)介紹: (一)求字符串長度 (1)strlen (二)長度不受限制的字符串函數(shù) (2)strcpy (3)strcat (4)strcmp (三)長度受限制的字符串函數(shù) (5)strncpy (6)strncat (7)strncmp (四)字符串查找 (8)strstr (9)strtok (五)錯誤信息報告 (10)strerror (六)

    2024年02月15日
    瀏覽(19)
  • C語言:字符函數(shù)和字符串函數(shù)詳解及部分函數(shù)的模擬實現(xiàn)(前篇)

    C語言:字符函數(shù)和字符串函數(shù)詳解及部分函數(shù)的模擬實現(xiàn)(前篇)

    前言: C語言中對 字符和字符串 的處理很是頻繁,但是C語言本身是沒有字符串類型的, 字符串通常放在 常量字符串 中或者 字符數(shù)組 中。 字符串常量 適用于那些對它不做修改的字符串函數(shù)。 本篇文章將會 重點介紹處理字符和字符串的庫函數(shù)的使用和注意事項。 strlen函數(shù)

    2024年02月06日
    瀏覽(34)
  • 【c語言】字符串函數(shù)的模擬實現(xiàn)(二)

    【c語言】字符串函數(shù)的模擬實現(xiàn)(二)

    strcat 的作用就是 字符串追加,即將一個字符串添加到另一個字符串末尾。 那既然要追加字符串,要怎么找到目標字符串的末尾呢?所以這就要求目標空間中要有 \\\'\\0\\\' ,找到 \\\'\\0\\\' 就是找到末尾了。需要注意的是此函數(shù)內部在找末尾時, 找的是目標空間中第一個 \\\'\\0\\\' 的位置 ,

    2024年02月07日
    瀏覽(28)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包