7.STL中string的一些超常用函数 (附习题)

目录

1.find

2.atoi

3.to_string

4.getline

[【leetcode 习题】](#【leetcode 习题】)

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

[125. 验证回文串](#125. 验证回文串)


1.find

1.查找第一次出现的目标字符串:说明:如果查找成功则输出查找到的第一个位置,否则返回-1;

s1.find(s2)

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;
int main() {
    string s1 = "abcdef";
    string s2 = "de";
    int ans = s1.find(s2) ;   //在S1中查找子串S2
    cout << ans << endl;
    system ("pause");
}

2.查找从指定位置开始的第一次出现的目标字符串

s1.find(s2, 2)

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;
int main() {
    string s1 = "abcdef";
    string s2 = "de";
    int ans = s1.find(s2, 2) ;   //从S1的第二个字符开始查找子串S2
    cout << ans << endl;
    system("pause");
}

2.atoi

atoi()函数的语法非常简单

复制代码
int atoi (const char * str);
  • int integer type which is the type of returned value.

    int整数类型,它是返回值的类型。

  • const char * is a constant char array that is equal to a string whose variable name is str.

    const char *是一个常量char数组,它等于一个变量名称为str

作用:在C和C ++中将字符串/字符转换为整数 (Convert String/Char To Integer In C and C++)

可以参考如下实例:

cpp 复制代码
#include <iostream>
#include <cstdlib>
 
int main()
{
    const char *str1 = "57";
    const char *str2 = "314.159";
    const char *str3 = "52345 some text";
    const char *str4 = "some text 25";
 
    int mynum1 = std::atoi(str1);
    int mynum2 = std::atoi(str2);
    int mynum3 = std::atoi(str3);
    int mynum4 = std::atoi(str4);
 
    std::cout << "atoi(\"" << str1 << "\") is " << mynum1 << '\n';
    std::cout << "atoi(\"" << str2 << "\") is " << mynum2 << '\n';
    std::cout << "atoi(\"" << str3 << "\") is " << mynum3 << '\n';
    std::cout << "atoi(\"" << str4 << "\") is " << mynum4 << '\n';
}
  • If given string or char array is floating-point like "314.159" in only integer part will be converted where the result will be "314"

    如果给定的字符串或char数组是浮点数,例如" 314.159",则仅整数部分将被转换,结果为" 314"

  • If there are some non-numerical chars in the given char array or string they will not convert and there will be no error where only the integer part will be converted. As an example "52345 some text" will be converted 52345

    如果给定的char数组或字符串中有一些非数字char,它们将不会转换,并且只有整数部分会被转换也不会出错。 例如," 52345 some text"将被转换为52345

  • If the start of the char array or string and there are numerical characters after them this will be converted into 0 as an integer value. As an example "some text 25" will be converted into 0.

    如果char数组或字符串的开头,并且后面有数字字符,则将其转换为0作为整数值。 例如,"一些文本25"将转换为0。

  • If the numerical characters are between non-numeric characters the conversion result will be 0 too.

    如果数字字符介于非数字字符之间,则转换结果也将为0。

  • If the char array or string starts with numeric character and after that, there is a non-numeric, and then numeric character only the starting numeric character will be converted. As an example "25 text 50" will be converted into 25.

    如果char数组或字符串以数字字符开头,并且之后是非数字字符,则仅将起始数字字符转换为数字字符。 例如," 25个文本50"将转换为25。

【总结来说】:字符转化为数字,是以起始为主要参考的

3.to_string

将数字常量转换为字符串,返回值为转换完毕的字符串

头文件:#include < string >(必须加)

string s = to_string(i); //将整数i转换为字符串表示形式

附:如果是string s = to_string('3'),则结果是s = 51。
需要对s = s -48; 才能得到正确的结果。

cpp 复制代码
#include <iostream>   
#include <string>     
using namespace std;
 
int main()
{
    string pi = "pi is " + std::to_string(3.1415926);
    string perfect = to_string(1 + 2 + 4 + 7 + 14) + " is a perfect number";
    cout << pi << '\n';
    cout << perfect << '\n';
    system("pause");
    return 0;
}

4.getline

作用:打印一行字符串(可打印空格)

应用:

题解:

【leetcode 习题】

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

!!! get以坐标为方式的查找次数加法 count [ s [ i ] ]+=1

125. 验证回文串

如果有兴趣了解原理,可以读一下下面这篇文章,来更深入的了解string:

STL 的string类怎么啦

相关推荐
✎ ﹏梦醒͜ღ҉繁华落℘3 分钟前
FreeRTOS学习笔记(应用)-- 各种 信号量的应用场景
笔记·学习
星星火柴9368 分钟前
笔记 | C++面向对象高级开发
开发语言·c++·笔记·学习
Coovally AI模型快速验证14 分钟前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
码界奇点15 分钟前
Rust 性能优化全流程从 flamegraph 定位瓶颈到 unsafe 与 SIMD 加速响应快
开发语言·性能优化·rust·simulated annealing
BeingACoder17 分钟前
【SAA】SpringAI Alibaba学习笔记(一):SSE与WS的区别以及如何注入多个AI模型
java·笔记·学习·saa·springai
悲伤小伞44 分钟前
Linux_Socket_UDP
linux·服务器·网络·c++·网络协议·udp
电院工程师1 小时前
SIMON64/128算法Verilog流水线实现(附Python实现)
python·嵌入式硬件·算法·密码学
轮到我狗叫了1 小时前
力扣.84柱状图中最大矩形 力扣.134加油站牛客.abb(hard 动态规划+哈希表)牛客.哈夫曼编码
算法·leetcode·职场和发展
丛雨要玩游戏1 小时前
字符函数和字符串函数
c语言·开发语言·算法
安全不再安全1 小时前
免杀技巧 - 早鸟注入详细学习笔记
linux·windows·笔记·学习·测试工具·web安全·网络安全