算法题-字符串

1.C++字符串

c++提供了一下两种类型的字符串表示形式:

  • c风格字符串
  • c++引入的string类类型

1.1C风格字符串

C 风格的字符串起源于 C 语言,并在 C++ 中继续得到支持。字符串实际上是使用 null 字符 \0 终止的一维字符数组。因此,一个以 null 结尾的字符串,包含了组成字符串的字符。
下面的声明和初始化创建了一个 RUNOOB 字符串。由于在数组的末尾存储了空字符,所以字符数组的大小比单词 RUNOOB 的字符数多一个。

char site[7] = {
   'R', 'U', 'N', 'O', 'O', 'B', '\0'};

依据数组初始化规则,您可以把上面的语句写成以下语句

char site[] = "RUNOOB";

在这里插入图片描述
其实,您不需要把 null 字符放在字符串常量的末尾。C++ 编译器会在初始化数组时,自动把 \0 放在字符串的末尾。让我们尝试输出上面的字符串

相关函数

字符串相关函数

1.2 C++中的string类

C++ 标准库提供了 string 类类型,支持上述所有的操作,另外还增加了其他更多的功能。我们将学习 C++ 标准库中的这个类,现在让我们先来看看下面这个实例:

现在您可能还无法透彻地理解这个实例,因为到目前为止我们还没有讨论类和对象。所以现在您可以只是粗略地看下这个实例,等理解了面向对象的概念之后再回头来理解这个实例

#include <iostream>
#include <string>
 
using namespace std;
 
int main ()
{
   
   string str1 = "runoob";
   string str2 = "google";
   string str3;
   int  len ;
 
   // 复制 str1 到 str3
   str3 = str1;
   cout << "str3 : " << str3 << endl;
 
   // 连接 str1 和 str2
   str3 = str1 + str2;
   cout << "str1 + str2 : " << str3 << endl;
 
   // 连接后,str3 的总长度
   len = str3.size();
   cout << "str3.size() :  " << len << endl;
 
   return 0;
}

当上面的代码被编译和执行时,它会产生下列结果:

str3 : runoob
str1 + str2 : runoobgoogle
str3.size() :  12

相关函数

函数 功能 用法例子
length 返回字符串的长度 size_t len = str.length();
size 返回字符串的长度(与length相同) size_t len = str.size();
empty 检查字符串是否为空 bool isEmpty = str.empty();
clear 清空字符串 str.clear();
append 在字符串末尾添加另一字符串或字符 str.append("world");str.append(1, '!');
push_back 在字符串末尾添加一个字符 str.push_back('!');
insert 在指定位置插入字符或字符串 str.insert(5, "abc");
erase 移除字符串中的字符或子字符串 str.erase(5, 3);
replace 用新字符串替换指定范围内的子字符串 str.replace(5, 3, "xyz");
substr 提取子字符串 std::string sub = str.substr(5, 3);
find 查找子字符串首次出现的位置 size_t pos = str.find("abc");
rfind 查找子字符串最后一次出现的位置 size_t pos = str.rfind("abc");
find_first_of 查找字符串中任意一个字符首次出现的位置 size_t pos = str.find_first_of("aeiou");
find_last_of 查找字符串中任意一个字符最后一次出现的位置 size_t pos = str.find_last_of("aeiou");
find_first_not_of 查找字符串中第一个不属于指定字符集合的位置 size_t pos = str.find_first_not_of("aeiou");
find_last_not_of 查找字符串中最后一个不属于指定字符集合的位置 size_t pos = str.find_last_not_of("aeiou");
compare 比较两个字符串 int result = str.compare("hello");
c_str 返回C风格字符串(以null结尾的字符数组) const char* cstr = str.c_str();
copy 将字符串的内容复制到字符数组中 str.copy(buffer, len);
resize 调整字符串大小 str.resize(20, '!');
std::stoi 将字符串转换为整数 int num = std::stoi("123");
std::stod 将字符串转换为双精度浮点数 double num = std::stod("123.45");
std::to_string 将数值转换为字符串 std::string str = std::to_string(123);
std::getline 从输入流读取一行到字符串 std::getline(std::cin, str);

2.字符串相关算法题

2.1反转字符串

题目

#include <iostream>
#include <vector>
#include <string>
#include <utility>
using namespace std;

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

2.2反转字符串II

题目

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
class Solution 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值