当前位置:首页 > C++知识 > 正文内容

【高级篇】C++ 中string的用法

亿万年的星光4年前 (2021-01-28)C++知识21212
0.概述

string是C++标准库的一个重要部分,本意是字符串,和字符数组不同的是,字符数组是通过一个一个字符模拟的字符串,而string本身就是字符串,string在处理字符串问题时,十分强大。

1.字符和字符串的区别

在C++语言中,字符和字符串有着严格的区别,

char  c;   // 字符,
c=‘s’;   // 字符的赋值用单引号

char  ary[10];   //字符数组
cin>>ary;   //字符数组的赋值一般用cin或scanf("%s",ary),但是这两种方法都不能读入包含空格的字符串

string s;   //字符串
s="hello world";   //字符串的赋值用双引号

3.字符串的输入和输出

使用string,建议引入string 头文件

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s; // 定义一个字符串
   getline(cin,s); //输入一个字符串
   cout<<s; //输出字符串
   return 0;
}

4.字符串的遍历

要去遍历一个字符串,就要知道字符串的长度,在C++中,可以通过

字符串名.size 和 字符串名.length 来确定字符串的长度

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s; // 定义一个字符串
   getline(cin,s); //    输入一个字符串
   cout<<"字符串的长度:"<<s.size()<<endl;  
   cout<<"字符串的长度:"<<s.length()<<endl;
   return 0;
}



可以看出,两者作用类似。而且输出的字符串的长度是包含字符单词和单词之间的。

知道了一个字符串的长度,就可以通过for循环去遍历字符串了,比如下面的这个例子:

输入一段字符,查找其中数字的个数

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s; // 定义一个字符串
   int sum=0;
   getline(cin,s); //    输入一个字符串
   for(int i=0;i<s.size();i++)
   {
       if(s[i]>='0'&& s[i]<='9')
           sum++;
   }
   cout<<sum;
   return 0;
}



可以看出,跟字符数组的用法类似。

5.string类的一些用法

1.拼接字符串

比如我们想把“hello”和“world”拼在一起显示 “hello world”

方式1:通过 “+” 符号

int main()
{
   string s1,s2,s3;
   s1="hello";
   s2="world";
   s3=s1+s2;
   cout<<s3;
   return 0;
}
//显示 helloworld

方式2:通过append方法

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s1,s2,s3;
   s1="hello";
   s2="world";
   s3=s1.append(s2);
   cout<<s3;
   return 0;
}
//显示helloworld

2.删除字符串 erase

erase参数一共有两个,表示要删除的起始位置和要删除的字符个数。

erase(start,num)

int main()
{
   string s="123456789";
//    s.erase(0,0);  //结果为 123456789
//    s.erase(0,1); //结果为  23456789
//    s.erase(1,2); // 1456789
//    s.erase(2,2); //1256789
   s.erase(2,4); //12789    
   cout<<s;
   return 0;
}

3. 字符串替换replace

replace的参数有三个,第一个是起始位置,第二个是要替换掉多少个,第三个是你要替换的字符串。

replace(start,num,str)

int main()
{
   string s="123456789";
  //s.replace(0,4,"w"); //结果w56789
   s.replace(2,3,"what"); //结果是12what6789    
   cout<<s;
   return 0;
}

4.查找字符串 find和rfind

首先,find和rfind的区别是,find是从前往后找,rfind是从后往前找。返回的是当前字符串第一次出现的位置。 如果没有找到,返回的是 s.npos。

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s="to be or not to be is a question?";
   
  //查找一个字符串
   cout<<s.find("to")<<endl; //结果是0;
   
  //倒叙查找一个字符串
   cout<<s.rfind("to")<<endl; //结果是13
   
  // 从某个位置开始查找一个字符串
   cout<<s.find("to",3)<<endl;//  结果是13
   
  //返回子串在母串中首次出现的位置
   string s2="o";
   cout<<s.find_first_of(s2)<<endl; //结果是1
   
  //返回子串在母串中最后一次出现的位置
   string s3="o";
   cout<<s.find_last_of(s3)<<endl; // 结果是30
       
   return 0;
}

5.截取字符串substr

参数有两个 substr(start,length) 表示从什么地方开始,截取几个字符

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s="to be or not to be is a question?";
   
   cout<<s.substr(0)<<endl; // 结果是 to be or not to be is a question?
   
   cout<<s.substr(0,2)<<endl; //结果是 to
   
   cout<<s.substr(1,4)<<endl;   //结果是o be
   
   return 0;
}

6.大小写转换

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
   string s="to be or not to be is a question?";
   
   for(int i=0;i<s.size();i++)
       s[i]=toupper(s[i]); //转大写
   
   cout<<s; //输出 TO BE OR NOT TO BE IS A QUESTION?
   
   for(int i=0;i<s.size();i++)
       s[i]=tolower(s[i]); //转小写
   cout<<s; //输出 to be or not to be is a question?
   return 0;

} //大小写转换的第二种用法

大小写转换的第二种写法

#include <iostream>
#include <string>
#include <algorithm>    // transform
using namespace std;
 
int main()
{
   string str = "abcdABCD";
   transform(str.begin(), str.end(), str.begin(), ::toupper);
   cout << str << endl;
   transform(str.begin(), str.end(), str.begin(), ::tolower);
   cout << str << endl;
   return 0;
}




7.字符串反转reverse
#include<iostream>
#include<string>
#include<cstdio>
#include<algorithm>  //使用reverse需要algorithm头文件
using namespace std;
int main()
{
   string s1="hello";
   string s2="hello world";
   reverse(s1.begin(),s1.end());// 反转s1
   cout<<s1<<endl; //输出: olleh
   reverse(s2.begin(),s2.end()); //反转s2
   cout<<s2<<endl; // 输出 dlrow olleh
   return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

数组的不确定长度输入

0.前言我们在学习数组的时候一般都会告诉你数组的长度,然后for循环去遍历。但是有一类问题是没有n的,也就是没有告诉长度的。1.方法第一种:(数组)#include<iostream>...

【数据结构】栈—表达式括号匹配

【数据结构】栈—表达式括号匹配

【题目描述】假设一个表达式有英文字母(小写)、运算符(+,—,*,/)和左右小(圆)括号构成,以“@”作为表达式的结束符。请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回“YES”;否则...

【数论】龟速乘

【数论】龟速乘

我们前面一篇文章学习了快速幂。它可以解决两类问题:a^b,(a^b)%c对于第一类,我们可以使用递归法或者迭代法可以求出,为了计算的快,我们可以引入位运算操作,但是目前来看,无论怎么优化都不能超过lo...

【题解】均分纸牌

【题目描述】有n堆纸牌,编号分别为 1,2,…, n。每堆上有若干张,但纸牌总数必为n的倍数。可以在任一堆上取若干张纸牌,然后移动。移牌规则为:在编号为1的堆上取的纸牌,只能移到编号为 2 的堆上;在...

【数据结构】栈(Stack)的介绍

栈是只能在某一端插入和删除的特殊线性表。栈就是一种类似桶堆积物品的数据结构,进行删除和插入的一端称栈顶,另一端称栈底。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为后进先出表(LIF...

2021 年青岛市程序设计竞赛试题(小学组)决赛

2021 年青岛市程序设计竞赛试题(小学组)决赛

1.方程求解【描述】输入正整数 a,b,c。求有多少组 x 和 y 满足 a*x+b*y=c 。x 和 y 都是非负整数。【输入】一行,包含三个正整数 a,b,c,两个整数之间用单个空格隔开。【输出】...