C++中的string getline(cin,s); cin>>s;

string中的erase和insert都与位置有关,这两个的用法尤为重要

读入带空格的字符串 getline(cin,s6); 读取字符到遇到换行,空格可读入,‘\n’直到结束
读入字符串不能带空格 cin>>s5;

1、string对象的定义和初始化以及读写

string s1;      默认构造函数,s1为空串

string s2(s1);   将s2初始化为s1的一个副本

string s3("valuee");   将s3初始化一个字符串面值副本

string s4(n,'c');   将s4 初始化为字符'c'的n个副本

cin>>s5;  读取有效字符,遇到空格结束

getline(cin,s6);  读取字符到遇到换行,空格可读入,‘\n’直到结束

getline(cin,s7,'a'); 一个直到‘a’结束,其中任何字符包括'\n'都能够读入

2、string对象操作

s.empty()  判断是否为空,bool型

s.size() 或 s.length() 返回字符的个数

s[n]  返回位置为n的字符,从0开始计数

s=s1+s2 连接字符串

字符串尾部追加可用s.append("abc")添加

3、string对象中字符的处理(头文件cctype)

    isalnum(c)  如果c是字母或数字,返回 true

    isalpha(c)  如果c是字母,返回true

    iscntrl(c)  c是控制符,返回true

    isdigit(c)  如果c是数组,返回true

    isgraph(c)  如果c不是空格,则可打印,,则为true

    islower(c)  如果c是小写字母,则为true

    isupper(c)  如果c是大写字符,则为true

    isprint(c)  如果c是可打印的字符,则为true

    ispunct(c)  如果c是标点符号,则为true

    isspace(c) 如果c是空白字符,则为true

    isxdigit(c) 如果c是十六进制数,则为true

    tolower(c) 如果c是大写字符,则返回其小写字母,否则直接返回c

    toupper(c)  跟tolower相反

4、string对象中一些函数(重点看删除函数)

/*-------------------------插入函数----------------------------------包括迭代器操作和下标操作,下标操作更灵活*/

s.insert( it , p );  把字符串p插入到it的位置

s.insert(p,n,t);   迭代器p元素之前插入n个t的副本

s.insert(p,b,e);      迭代器p元素之前插入迭代器b到e之间的所有元素

s.insert(p,s2,poe2,len); 在下标p之前插入s2下标从poe2开始长度为len的元素

s.insert(pos,cp,len);  下标pos之前插入cp数组的前len个元素。

/*-----------------------替换函数-------------------------------*/

s.assign(b,e);  用迭代器b到e范围内的元素替换s

s.assign(n,t);  用n个t的副本替换s

a.assign(s1,pos2,len);从s1的下标pos2开始连续替换len个。

s.replace ( 3 , 3 , " good " ) ;   从第三个起连续三个替换为good

s.substr(i,j)   截取s串中从i到j的子串  //string::npos  判断字符串是否结束

/*-----------------------删除函数-----------------------------*/

(1)erase(pos,n); 删除从pos开始的n个字符,比如erase(0,1)就是删除第一个字符//重要
(2)erase(position);删除position处的一个字符(position是个string类型的迭代器)
(3)erase(first,last);删除从first到last之间的字符(first和last都是迭代器)

/*----------------------其他函数-----------------------------*/

s.find ( " cat " ) ;  超找第一个出现的字符串”cat“,返回其下标值,查不到返回 4294967295,也可查找字符;

s.append(args); 将args接到s的后面

s.compare ( " good " ) ;  s与”good“比较相等返回0,比"good"大返回1,小则返回-1;

reverse ( s.begin(), s.end () );  反向排序函数,即字符串反转函数

https://blog.csdn.net/sinat_20265495/article/details/52502315

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值