【C/C++】涉及string类的经典OJ编程题

news/2024/9/24 18:34:07/

【C/C++】涉及string类的经典OJ编程题

  • 一. 把字符串转化成整数(atoi)
    • 解法一:(不用long)
    • 完整代码:
    • 解法二:(用long)
  • 二.字符串相加
    • 代码实现(含注释):
  • 三.反转字符串
    • 代码实现:
  • 四.字符串中的第一个唯一字符
    • 解法一:
    • 解法二:(推荐)

一. 把字符串转化成整数(atoi)

点这里:本题LeetCode链接
该题源代码声明:
作者:Krahets
链接:https://leetcode.cn/problems/ba-zi-fu-chuan-zhuan-huan-cheng-zheng-shu-lcof/solutions/201301/mian-shi-ti-67-ba-zi-fu-chuan-zhuan-huan-cheng-z-4/
来源:力扣(LeetCode)

在这里插入图片描述

解法一:(不用long)

首先来看该题要用到的所以的变量的定义和初始化

  int res = 0, bndry = INT_MAX / 10;int i = 0, sign = 1, length = str.size();

第一步:

  1. 判断字符串是否为空字符串
  2. 读取字符串并丢弃无用的前导空歌并且判断该字符串是否为全为空格的字符串。通过对下标 i 的控制来实现。
    代码实现:
 if(length == 0) return 0;while(str[i] == ' ')if(++i == length) return 0;//若不是空字符串,i走到符号位

第二步:
判断字符的正负
代码实现:

if(str[i] == '-') sign = -1;
if(str[i] == '-' || str[i] == '+') i++;//让i走到符号位后的第一个数字字符

第三步:(关键)
(最大最小数值)边界的处理
一旦遇到非数字字符直接返回0;此时的 j 为第一个数字字符。
变量的定义和初始化:int res = 0, bndry = INT_MAX / 10; (INT_MAX )等于2147483647,注意这里的个位数字7;注意初始化的bndry = 214748364;
再看这句代码:res = res * 10 + (str[j] - ‘0’);通过这句代码可以将字符数字转发为对应大小的整形数值。现在就可以理解 if 语句里面的条件判断:

  1. 当res一旦大于bndry = 214748364;往下走完语句res = res * 10 + (str[j] - ‘0’);时,res就会越界;
  2. 当(res == bndry && str[j] > ‘7’),此时下标 j 指向的字符大于7时,往下走完语句res = res * 10 + (str[j] - ‘0’);时,res也会越界;

代码实现:

 for(int j = i; j < length; j++) {if(str[j] < '0' || str[j] > '9') break;if(res > bndry || res == bndry && str[j] > '7')return sign == 1 ? INT_MAX : INT_MIN;res = res * 10 + (str[j] - '0');}

完整代码:

class Solution {
public:int myAtoi(string str) {int res = 0, bndry = INT_MAX / 10;int i = 0, sign = 1, length = str.size();if(length == 0) return 0;while(str[i] == ' ')if(++i == length) return 0;if(str[i] == '-') sign = -1;if(str[i] == '-' || str[i] == '+') i++;for(int j = i; j < length; j++) {if(str[j] < '0' || str[j] > '9') break;if(res > bndry || res == bndry && str[j] > '7')return sign == 1 ? INT_MAX : INT_MIN;res = res * 10 + (str[j] - '0');}return sign * res;}
};

解法二:(用long)

用long的前提:(操作系统)环境能存储 64 位大小的有符号整数

class Solution {
public:int myAtoi(string str) {long int res = 0, bndry = INT_MAX / 10;int i = 0, sign = 1, length = str.size();if(length == 0) return 0;while(str[i] == ' '){i++;if(i == length)return 0;}if(str[i] == '-')sign = -1;if(str[i] == '-' || str[i] == '+') i++;for(int j = i; j < length; j++){if(str[j] > '9' || str[j] < '0')return sign * res;res = res * 10 + str[j] - '0';//如果不用long,这句代码可能会造成res溢出int max;无法通过部分测试if(res > INT_MAX)return sign == 1 ? INT_MAX : INT_MIN;}return sign * res;}
};

二.字符串相加

点这里:本题LeetCode链接
在这里插入图片描述

代码实现(含注释):

class Solution {
public:string addStrings(string num1, string num2) {string tmp;int count = 0;//用于进位int gap1 = num1.end() - num1.begin() - 1;//字符串1尾下标int gap2 = num2.end() - num2.begin() - 1;//字符串2尾下标while(gap1 >= 0 || gap2 >= 0){int x = gap1 >= 0 ? num1[gap1] - '0' : 0;//将数字字符串转换为对应整形数字int y = gap2 >= 0 ? num2[gap2] - '0' : 0;//当下标走到负数将其转换为0int sum = x + y + count;//对应两两相加,在加上进位数值count = sum / 10;//得进位数值sum %= 10;//得个位数值tmp += (sum + '0');//依次拼接(逆序)gap1--;gap2--;}if(count == 1)//解决一个字符串为“0”,另一个为“9”,还有最高位未进位的情况{tmp += '1';}reverse(tmp.begin(), tmp.end());//颠倒为顺序return tmp;}
};

三.反转字符串

点这里:本题LeetCode链接
在这里插入图片描述

代码实现:

class Solution {
public:void reverseString(vector<char>& s) {int begin = 0;int end = s.size() - 1;while(begin < end){swap(s[begin], s[end]);begin++;end--;}}
};

四.字符串中的第一个唯一字符

点这里:本题LeetCode链接
在这里插入图片描述

解法一:

原理:两两比较字符串中的所以字符,通过计数来判断是否有相同字符

class Solution {
public:int firstUniqChar(string s) {for(int i = 0; i < s.size(); i++){int count = 0;int j = 0;for(; j < s.size(); j++){if(s[i] == s[j] && i != j)break;if(s[i] != s[j])count++;}if(count == s.size() - 1)return i;}return -1;}
};

解法二:(推荐)

原理:如果从左往右找,和从右往左找同一个字符,返回它们的下标相同,则在给出的字符串中该字符有且只有这一个
s.find(s[i]) : 返回字符串s中从左向右查找s[i]第一次出现的位置;
s.rfind(s[i]) : 返回字符串s中从右向左查找s[i]第一次出现的位置;
解法二声明:
作者:WTY2002
链接:https://leetcode.cn/problems/first-unique-character-in-a-string/solutions/948758/qiao-yong-stringrong-qi-de-cha-zhao-han-y1507/
来源:力扣(LeetCode)


class Solution {
public:int firstUniqChar(string s) {for(int i = 0; i < s.size() ; i++){if(s.find(s[i]) == s.rfind(s[i])){return i;}}return -1;}
};

http://www.ppmy.cn/news/1529925.html

相关文章

AutoX.js向后端传输二进制数据

android的JavaScript自动化软件用过Hamibot和AutoX.js 不过在向后端传输二进制数据时都有些限制&#xff0c;不如浏览器前端那么自由。Hamibot的http按文档应该时能支持传字节数组&#xff0c;但是实际上应该还没有支持。AutoX.js的http也是这样&#xff0c;但是AutoX.js还支持…

路由器全局配置DHCP实验简述

一、路由器配置 reset saved-configuration Warning: The action will delete the saved configuration in the device. The configuration will be erased to reconfigure. Continue? [Y/N]:y Warning: Now clearing the configuration in the device. Info: Succeeded in c…

微服务开发

微服务的架构使得小改动频繁上线和下线非常容易&#xff0c;可以直接在运行的产品上推送一个新的功能或者下线一个无用的功能&#xff1a;获得持续交付的能力。 SOA 的起源 SOA&#xff08;Service-Oriented Architecture&#xff09;&#xff1a;将应用组织成一个独立的功能…

【字符函数】strcpy函数(字符串复制函数)+strcat函数(字符串追加)+strcmp函数(字符串比较)【笔记】

1.复制函数--------------strcpy函数 函数使用 char*strcpy&#xff08;char* destination, const char* source&#xff09; strcpy函数用于拷贝字符串&#xff0c;即将一个字符串中的内容拷贝到另一个字符串中&#xff08;会覆盖原字符串内容&#xff09;。它的参数是两个指…

基于单片机的车载传感器数据处理系统

1总体方案设计 本次新能源汽车车载传感器数据处理系统&#xff0c;其系统总体架构如图2.1所示&#xff0c;采用STM32f103单片机作为控制器&#xff0c;通过DH11传感器实现温湿度检测&#xff1b;通过光敏电阻实现光照检测&#xff1b;同时其检测的信息通过ESP8266 WiFi模块传输…

如何选择适合的编程工具提高工作效率

---  随着科技的发展&#xff0c;编程已经成为各行各业不可或缺的一部分。在忙碌的工作环境中&#xff0c;如何选择合适的编程工具成为了每个开发者提升工作效率的关键。智能的代码编辑器、强大的版本控制工具、还是那些让你事半功倍的自动化脚本&#xff1f;让我们一起探讨&…

【Docker】Docker上安装MySql8和Redis

MySql安装 对于镜像中需要持久化保存的⽂件&#xff0c;需要通过-v挂载到宿主机上&#xff0c;这样这些⽂件才不会随着容器关闭⽽消失。 对于MySQL&#xff0c;需要将他的⽇志⽂件、数据⽂件和配置⽂件挂载到宿主机上。 # 拉取镜像 docker pull mysql:8 # 启动mysql并配置⼯作…

如何从GitHub上Clone项目

GitHub 是全球最大的开源代码托管平台之一&#xff0c;开发者可以在上面分享代码&#xff0c;协作开发&#xff0c;提交贡献。对于程序员来说&#xff0c;从 GitHub 上获取代码并在本地运行和修改是非常重要的一个技能。本文将深入介绍如何从 GitHub 上 clone 项目&#xff0c;…