手写方法实现字符串例如:“123“与整型例如:123相互转化(面试必会)

2024-06-22 01:28

本文主要是介绍手写方法实现字符串例如:“123“与整型例如:123相互转化(面试必会),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

二、字符串类型转化为整型

1. 初始化变量

2.定义字符串索引值

3.思考如何将字符'1'转化为数字1

4. 转化思路

5.考虑字符串转化负数例:-123456

6.完整代码

四、最后


一、前言

        在c语言和c++中,有许许多多的数据类型相互转化的方法,这里我就不一一列举了,实在太多了。但是如果让你自己实现类型的转化的方法,你会有一个具体的思路吗?

        而且这也是在面试中面试官会经常问的问题,所以下面我就带着大家以字符串和整形为例,实现数据类型相互转换的方法。

二、字符串类型转化为整型

       字符串类型转化为整型思路比较简单,下面我将以字符串类型str转换为int 类型value为例,讲解思路以及方法。

char str[] { "123456" };

1. 初始化变量

        我们首先初始化两个变量类型,str和num作为互相转化的值。

	//字符串初始化char str[]{ "123456" };//num初始化 int num{ 0 };
2.定义字符串索引值

        将字符串"123456"转化为整型123456,我们需要遍历字符串的每一项,对每一个字符元素进行单独处理,所以我们还需要定义一个第三变量index作为字符串的索引值。

unsigned short index = 0;

如图所示:

3.思考如何将字符'1'转化为数字1

        我们在通过索引值index++取出字符串中的每一项后,同时还要思考如何将每一项的字符转化为数字。例如: ‘1’ 转化为数字 1。

        这一点我们可以根据char字符的本质来思考,我们都知道char字符的本质其实就是数字,在计算机中我们通过字符编码表来进行字符和数字的转化,例如:ASCII表,unicode表等等。所以我们可以通过字符‘1’在ASCII表中的位置来进行数字的转化。

              所以根据上图所示我们可以得出规律,‘1’ 减去48就可以得到数字1.

	char a = '1';std::cout << a - 48;; // 1
4. 转化思路

        通过while循环遍历字符的每一项,同时对num的值处理为1,12,123,1234,12345,123456,我们发现规律都是前一项乘以10 然后加上后一项。

如图:

     

代码为:

    while (str[index]){num = num * 10 + str[index++] - 48;}
5.考虑字符串转化负数例:-123456

        如果字符串为"-123456"这种形式,我们的索引值index就要从1开始自增了,而且最后的结果值还有乘以(-1).

        那么index初始化为:

unsigned short index = str[0] == '-' ? 1 : 0;

        最后num的值为:

num = str[0] == '-' ? num * (-1) : num;
6.完整代码

        代码为:

    //字符串初始化char str[]{ "123456" };  //char str[]{ "-123456" };//num初始化 int num{ 0 };// 索引值iunsigned short index = str[0] == '-' ? 1 : 0;while (str[index]){num = num * 10 + str[index++] - 48;}num = str[0] == '-' ? num * (-1) : num;std::cout << num << std::endl; // 123456

四、最后

        输出结果为:

        本章只实现了字符串到整形的转化,代码实现有很多种写法和形式,我只提供了一种写法。同时我还会继续更新整型到字符串的转化,还请大家多多支持,拯救下秃头的博主吧!!!!

这篇关于手写方法实现字符串例如:“123“与整型例如:123相互转化(面试必会)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1082894

相关文章

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

usaco 1.2 Palindromic Squares(进制转化)

考察进制转化 注意一些细节就可以了 直接上代码: /*ID: who jayLANG: C++TASK: palsquare*/#include<stdio.h>int x[20],xlen,y[20],ylen,B;void change(int n){int m;m=n;xlen=0;while(m){x[++xlen]=m%B;m/=B;}m=n*n;ylen=0;whi

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施: