C++字符串函数与字符数组函数

news/2024/6/18 21:24:50 标签: c/c++

C++ 字符串(string类)函数
首先明确 字符串是从第0位 开始存储的
即 string s="123"; s[0]==1;

string ss="0123456789";
string ss2;
1.求长度
int len=ss.length(); //求字符串ss的长度返回值赋给len
(此时len==10)
 
2.提取子串
string ss2;
ss2=ss.substr(pos);//返回从pos开始的(包括pos)的子串赋给ss2;
(例 ss2=ss.substr(8);//此时ss2=="89")

ss2=ss.substr(pos,len);//返回从pos开始的len位子串赋给ss2;
(例 ss2=ss.substr(1,2);//此时ss2=="12");

3.子串查找
int where=ss.find(ss2);//查找ss2在ss中的位置并返回ss2第一个字符在ss中的位置,若找不到则返回-1;
(例 ss2="23";int where=ss.find(ss2);//where==2
    ss2="00",int where=ss.find(ss2);//where==-1);

int where=ss.find(ss2,pos);//从ss的第pos(pos>=0)位开始查找,返回ss2在ss中的位置,若找不到则返回-1;
(例 ss2="78";int where=ss.find(ss2,7);//where==7
     ss2="78";int where=ss.find(ss2.8);//where==-1);
 ---------------------------------以上为手打,以下..囧rz-----------------------------------------

这3种 是字符串最常用的操作,几种不常用的如下
6. 插入字符串
   不是赋值语句。
   str1.insert(pos1,str2); //如str1.insert(2,str2)则str1=”heworldllo,”
    str1.insert(pos1,str2,pos2,len2);
    str1.insert(pos1,numchar,char); numchar是插入次数,char是要插入的字符。
7. 替换字符串
   str1.replace(pos1,str2);
   str1.replace(pos1,str2,pos2,len2);
8. 删除字符串
   str.erase(pos,len)
   str.clear();
9. 交换字符串
   swap(str1,str2);

 

字符数组:
一、用字符数组来存储字符串:
char st1[100],st2[100] ; //字符数组说明
cin>>st1>>st2;
long a,b;
输入:hello, world
则st1={‘h’,’e’,’l’,’l’,’o’,’,’,’\0’}
st2={‘w’,’o’,’r’,’l’,’d’,’\0}
字符’\0’为字符串结束标志
1. 字符数组长度
   strlen(st1); //如a=strlen(st1);b=strlen(st2); 则a=6,b=5
2. 字符数组比较
   不能直接比较,st1>st2是错误的,要用strcmp()函数
   strcmp(st1,st2); //st1=st2相等则输出0,st1<st2输出-1,st1>st2输出1
   strncmp(st1,st2,n);   把st1,st2的前n个进行比较。
3. 连接字符数组
   不能直接用st1=st1+st2;用strcat()函数
   strcat(st1,st2); //将st1和st2连接后赋给st1,本例连接后st1为”hello,world”
   strncat(st1,st2,n);   n表示连接上st2的前n个给st1,在最后不要加'\0'。
4. 替换
   strcpy(st1,st2); //用st2的值替换st1的值,字符数组不能如此赋值st1=st2或st1[]=st2[]都是错误的
   本例中st1值被替代为”world”
   strncpy(st1,st2,n); n表示复制st2的前n个给st1,在最后要加'\0'。
5. 其他函数
strchr(st1,ch) //ch为要找的字符。如strchr(st1,’e’);会截取出st1中以字母’e’开头的字符串,要用string类型的来存储,如string c1; c1=strchr(st1,’e’); 则c1为”ello”
   strspn(st1,st2); //返回st1起始部分匹配st2中任意字符的字符数。本例中”hello,”中的第一个字符’h’不能在”world”中找到匹配字符,因此返回值为0。如st1=”rose”;st2=”worse”;则返回值为4,因为rose在worse中都能找到匹配字符。
   strrev(); //颠倒字符串

转载于:https://www.cnblogs.com/xujian9502/archive/2012/01/04/2312431.html


http://www.niftyadmin.cn/n/1580137.html

相关文章

回馈读者

360buy上&#xff0c;对我的书《QoS在IOS中的实现与应用》打5星的评价 &#xff1a; &#xff08;1&#xff09;读者&#xff1a;永冻黎明说“世面上感觉就这么一本qos的书能看了&#xff0c;资料匮乏的年代啊……良好的中文教材- -”&#xff08;2&#xff09;读者&#xff1a…

NetBeans Sources as a Platform

http://blogs.oracle.com/geertjan/entry/netbeans_sources_as_a_platform——————————————————————————————————————————————————————————————————————————————NetBeans Sources as a Platform …

在网页中加入flv视频

首先下载http://www.cgfans.net/bbs/Medias/2007/10/jw_flv_player.zip flv播放器下载下来。 使用方法&#xff1a;如果你仅需要播放一个FLV文件[例如“video.flv”],那么只要把“video.flv”和压缩包内的flvplayer.swf复制到同一个目录内,然后在页面内添加 程序代码 <objec…

[转]double free or corruption (!prev): 0x080644c8 ***

写了一个多线程的代码&#xff0c;在主线程中申请了一块内存&#xff0c;在另一个线程中释放内存&#xff0c;老出错误&#xff0c;不知道是怎么回事。 *** glibc detected *** /home/ydx/vehicle-program/vehicle-v1.0/t: double free or corruption (!prev): 0x080644c8 *** …

[收藏]iframe的WPO优化技巧

为什么80%的码农都做不了架构师&#xff1f;>>> http://www.webusability.cn/howto-wpo-for-iframe-460/ 转载于:https://my.oschina.net/leeoo/blog/39101

写在新年伊始

快过年了&#xff0c;今天一个人在家折腾了一天&#xff0c;打扫屋子&#xff0c;现在刚刚坐下来。遂燃起一支烟&#xff0c;泡上一杯北京人都喜欢的花茶&#xff0c;放上一张CD&#xff0c;享受一下。 很久没有写过东西了&#xff0c;博客也很久没有写了。在这新旧交替的时刻&…

ZOOKEEPER启动遇到显示IT IS PROBABLY NOT RUNNING的众多问题解决

加粗样式 ZOOKEEPER启动遇到显示IT IS PROBABLY NOT RUNNING的问题解决 本人是启动三台虚拟机分别是hadoop01&#xff0c;hadoop02,hadoop03&#xff0c;我在主节点启动zookeeper的zkServer.sh start服务后&#xff0c;在通过status查看其状态&#xff0c;发现第三台hadoop03节…

匹配一个字符

/[Ll]ove/ []表示匹配括号字符集中的一个字符即可。在本例子中&#xff0c;vi将寻找包含Love或者love的行。转载于:https://blog.51cto.com/huyanshu/767732