模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题

这篇具有很好参考价值的文章主要介绍了模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

各位朋友们,大家好啊!今天我为大家分享的知识是如何模拟实现atoi函数。相信大家如果能够理解这个知识,对大家以后的刷题是有帮助的。

什么是atoi函数(atoi函数的作用)

我们要想实现某个函数,我们肯定要先知道这个函数的作用是什么,然后我们再根据它的作用来自己实现。我们先来看看stoi函数在库函数中是怎么样的吧。

int atoi (const char * str);

这函数的参数只有一个字符串的地址,它的返回类型是一个整型类型。
模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题
这句话的意思是:
该函数首先根据需要丢弃尽可能多的空格字符(如在 isspace 中),直到找到第一个非空格字符。然后,从此字符开始,取一个可选的首字母加号或减号,后跟尽可能多的 10 进制数字,并将它们解释为数值。

字符串可以在构成整数的字符之后包含其他字符,这些字符将被忽略,并且对此函数的行为没有影响。

如果 str 中的第一个非空格字符序列不是有效的整数,或者由于 str 为空或仅包含空格字符而不存在此类序列,则不执行转换并返回零。

先直接使用库函数看看这个函数是什么作用

我们要想使用atoi这个函数,我们需要引用#include这个头文件。

都是正整数字符的字符串

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

int main()
{
	char* arr = "1234";   //我们先举一个正整数的例子
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题

含有负号的整数字符的字符串

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

int main()
{
	char* arr = "-1234";   //负整数
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题

含有非数字字符的字符串,且非数字字符都在一起

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

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

	return 0;
}

模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题

数字字符跟非数字字符交叉出现

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

int main()
{
	char* arr = "-1234a23cd";  //数字跟字母交叉出现
	int ret = atoi(arr);
	printf("%d\n", ret);

	return 0;
}

模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题
通过这几种代码,我们大概可以知道,atoi函数在遇到非数字字符就会停止读取了。

模拟实现atoi函数

我们实现atoi函数主要针对这些问题:

  1. 空指针。当传入的参数是NULL时,我们应该对其做出判断,以防出现非法访问。
  2. 空字符串。当传入的字符串为空时,我们就返回0
      • .当传入的字符串中第一个字符时’+‘或者’-'的时候,我们需要判断这个字符串的正负性。
  3. 非数字字符。当字符串中出现了非数字字符的时候,我们需要直接停止当前函数并返回已经转换完成的数字。
  4. 越界。因为在库函数中,atoi函数返回的是int类型,但是当我们传入的字符串长度很长时,那么这个字符串在转换为整形的时候,可能会出现超过int所表示的范围的时候。这时候我们就可以停止当前函数并返回已经转换完成的整数。下面就是代码实现。
#include<stdio.h>
#include<limits.h>  //int类型的取值范围
#include<ctype.h>   //判断是否为数字字符
#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是来决定你最终的整数的正负性
	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;
}

模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题

leedcode相关题目

leetcode之字符串转换整数 (atoi)

题目要求

请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。

函数 myAtoi(string s) 的算法如下:

读入字符串并丢弃无用的前导空格
检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正。
读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
将前面步骤读入的这些数字转换为整数(即,“123” -> 123, “0032” -> 32)。如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。
如果整数数超过 32 位有符号整数范围 [−231, 231 − 1] ,需要截断这个整数,使其保持在这个范围内。具体来说,小于 −231 的整数应该被固定为 −231 ,大于 231 − 1 的整数应该被固定为 231 − 1 。
返回整数作为最终结果。

注意:

本题中的空白字符只包括空格字符 ’ ’ 。
除前导空格或数字后的其余字符串外,请勿忽略 任何其他字符。

代码实现

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;
}

模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题

小结

大家可以自己去写写这道题,巩固下这个知识。那么到这里,我的这次分享就结束了,如果有错误,欢迎大家指出来,如果觉得博主写的不错记得给个赞哦。非常感谢!!!文章来源地址https://www.toymoban.com/news/detail-418427.html

到了这里,关于模拟实现atoi函数(将数字字符串转换为整型)附加leetcode练习题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 字符函数和字符串函数的模拟实现

    字符函数和字符串函数的模拟实现

    求字符串长度 strlen  长度不受限制的字符串函数 strcpy strcmp strcat 长度受限制的字符串函数 strnlen strncmp strncpy strncat 字符串查找 strstr strtok 错误信息报告 strerror 内存操作函数 memcpy memmove memset memcmp  首先我们来看strlen 字符串是以‘\\0’为结束标志,strlen函数返回的是‘\\0’出现

    2024年02月13日
    浏览(6)
  • 字符函数和字符串函数解析及模拟实现

    字符函数和字符串函数解析及模拟实现

    字符串以’\\0’作为结束标志,strlen函数返回的是在字符串中’\\0’前面出现过的字符个数(不包括’\\0’)。 参数指向的字符串必须以’\\0’结束。 注意函数的返回值位size_t, 是无符号的 。 Copies the C string pointed by source into the array pointed by destination, including the terminating null c

    2024年02月16日
    浏览(7)
  • 高阶C语言|字符函数和字符串函数--函数的模拟实现

    高阶C语言|字符函数和字符串函数--函数的模拟实现

    C语言中对字符和字符串的处理很是频繁,但是C语言本身是没有字符串类型的,字符串通常放在 常量字符串 中或者 字符数组 中。 字符串常量 适用于那些对它不做修改的字符串函数 size_t代表strlen函数返回的是一个无符号整形,str指向的是字符串,接收字符串的地址 字符串已

    2024年02月16日
    浏览(10)
  • 字符和字符串的库函数模拟与实现

    字符和字符串的库函数模拟与实现

    前言: 相信大家平常在写代码的时候,用代码解决实际问题时苦于某种功能的实现,而望而止步,这个时候库函数的好处就体现出来了,当然个人代码编写能力强的可以自己创建一个函数,不过相当于库函数来说却是浪费了一点时间,库函数的准确性和有效性对我们的好处就

    2024年02月10日
    浏览(10)
  • C/C++字符函数和字符串函数模拟实现与详解————长度不受限制的字符串函数

    C/C++字符函数和字符串函数模拟实现与详解————长度不受限制的字符串函数

    个人主页:点我进入主页 专栏分类:C语言初阶      C语言程序设计————KTV       C语言小游戏     C语言进阶 C语言刷题 欢迎大家点赞,评论,收藏。 一起努力,一起奔赴大厂。 目录   1.前言  2strlen函数   3.strcpy函数 4.strcat函数 5.strcmp函数           对于字符串

    2024年02月07日
    浏览(7)
  • 深入探索字符串函数与模拟实现

    深入探索字符串函数与模拟实现

      目录  前言: 一.常见函数的介绍与模拟实现 一.strlen函数 1.1  strlen函数的介绍 1.2  strlen的模拟实现(三种方式实现) 第一种:计数器的方式 第二种:递归的方式 第三种:指针-指针的方式 二.strcpy函数与strncpy函数 2.1  strcpy函数的介绍  2.2strncpy函数的介绍  2.3  strcpy的模

    2024年02月16日
    浏览(7)
  • 【C语言】字符函数和字符串函数的详细教学和模拟实现

    【C语言】字符函数和字符串函数的详细教学和模拟实现

    🚀write in front🚀 🔎大家好,我是gugugu。希望你看完之后,能对你有所帮助,不足请指正!共同学习交流🔎 🆔本文由 gugugu 原创 CSDN首发🐒 如需转载还请通知⚠ 📝个人主页:gugugu—精品博客 🎁欢迎各位→点赞👍 + 收藏⭐️ + 留言📝​ 📣系列专栏:gugugu的精品博客 ✉️

    2024年02月08日
    浏览(8)
  • 【C语言】字符函数和字符串函数(一)—>库函数的介绍与模拟实现

    【C语言】字符函数和字符串函数(一)—>库函数的介绍与模拟实现

    目录 前言: 一、函数介绍: (一)求字符串长度 (1)strlen (二)长度不受限制的字符串函数 (2)strcpy (3)strcat (4)strcmp (三)长度受限制的字符串函数 (5)strncpy (6)strncat (7)strncmp (四)字符串查找 (8)strstr (9)strtok (五)错误信息报告 (10)strerror (六)

    2024年02月15日
    浏览(9)
  • C语言:字符函数和字符串函数详解及部分函数的模拟实现(前篇)

    C语言:字符函数和字符串函数详解及部分函数的模拟实现(前篇)

    前言: C语言中对 字符和字符串 的处理很是频繁,但是C语言本身是没有字符串类型的, 字符串通常放在 常量字符串 中或者 字符数组 中。 字符串常量 适用于那些对它不做修改的字符串函数。 本篇文章将会 重点介绍处理字符和字符串的库函数的使用和注意事项。 strlen函数

    2024年02月06日
    浏览(9)
  • 【c语言】字符串函数的模拟实现(二)

    【c语言】字符串函数的模拟实现(二)

    strcat 的作用就是 字符串追加,即将一个字符串添加到另一个字符串末尾。 那既然要追加字符串,要怎么找到目标字符串的末尾呢?所以这就要求目标空间中要有 \\\'\\0\\\' ,找到 \\\'\\0\\\' 就是找到末尾了。需要注意的是此函数内部在找末尾时, 找的是目标空间中第一个 \\\'\\0\\\' 的位置 ,

    2024年02月07日
    浏览(8)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包