常用数据结构与算法(字符串).ppt
《常用数据结构与算法(字符串).ppt》由会员分享,可在线阅读,更多相关《常用数据结构与算法(字符串).ppt(55页珍藏版)》请在三一办公上搜索。
1、第7章 常用数据结构与算法,7.1 字符串,字符串是应用程序和用户交互的主要方式之一。.NET提供了几个类来快速实现字符串操作,包括String、StringBuilder等。,2,7.1.1 静态字符串String,System.String是最常用的字符串操作类。下面从各个应用的角度对String类进行详细的介绍。1.比较字符串比较字符串是指按照字典排序规则,判定两个字符的相对大小。在String类中,常用的比较字符串的方法包括Compare、CompareTo、CompareOrdinal以及Equals。,3,7.1.1 静态字符串String,(1)Compare方法 Compare
2、方法是String类的静态方法,用于全面比较两个字符串对象。下面使用Compare方法来比较两个字符串,输出结果如注释语句所示。/定义两个String对象,并对其赋值 System.String strA=Hello;System.String strB=World;,4,7.1.1 静态字符串String,/Compare Console.WriteLine(String.Compare(strA,strB);/-1 Console.WriteLine(String.Compare(strA,strA);/0 Console.WriteLine(String.Compare(strB,str
3、A);/1,5,7.1.1 静态字符串String,(2)CompareTo方法 作用与Compare类似,返回值也相同。CompareTo与Compare相比,区别在于:CompareTo不是静态方法,可以通过一个String对象调用;CompareTo没有重载形式,只能按照大小写敏感方式比较两个整串。,6,7.1.1 静态字符串String,CompareTo方法的使用如下代码所示:/定义两个String对象,并对其赋值 System.String strA=Hello;System.String strB=World;/CompareTo Console.WriteLine(strA.C
4、ompareTo(strB);/-1 Console.WriteLine(strB.CompareTo(strA);/1Console.WriteLine(strA.CompareTo(strA);/0,7,7.1.1 静态字符串String,(3)Equals方法 Equals方法用于方便地判定两个字符串是否相同,有两种重载形式:public bool Equals(string)public static bool Equals(string,string)如果两个字符串相等,Equals()返回值为True;否则,返回False。Equals方法的使用如下代码所示:Console.Wri
5、teLine(String.Equals(strA,strB);/false Console.WriteLine(strA.Equals(strB);/false,8,7.1.1 静态字符串String,(4)比较运算符 String支持两个比较运算符“=”、“!=”,分别用于判定两个字符是否相等和不等,并区分大小写。下例中,使用“=”、“!=”对“Hello”和“World”进行比较。/=和!=Console.WriteLine(strA=strB);/false Console.WriteLine(strA!=strB);/true,9,7.1.1 静态字符串String,2.定位字符和子
6、串定位子串是指在一个字符串寻找其中包含的子串或者某个字符,在String类中,常用的定位子串和字符的方法包括StartWith/EndsWith、IndexOf/LastIndexOf以及IndexOfAny/LastIndexOf。,10,7.1.1 静态字符串String,(1)StartWith/EndsWith方法 StartWith方法可以判定一个字符串对象是否以另一个子字符串开头,如果是返回True;否则返回False。其定义为:public bool StartsWith(string value)其中,参数value即待判定的子字符串。Console.WriteLine(str
7、A.StartsWith(He);/true Console.WriteLine(strA.StartsWith(She);/falseEndsWith方法判定一个字符串是否以另一个子字符串结尾。,11,7.1.1 静态字符串String,(2)IndexOf/LastIndexOf方法 IndexOf方法用于搜索一个字符串,某个特定的字符或子串第一次出现的位置,该方法区分大小写,并从字符串的首字符开始以计数。如果字符串中不包含这个字符或子串,则返回-1。定位字符:int IndexOf(char value)int IndexOf(char value,int startIndex)int
8、IndexOf(char value,int startIndex,int count)下例在“Hello”中寻找字符“l”第一次出现的位置。Console.WriteLine(strA.IndexOf(l);/2,12,7.1.1 静态字符串String,定位子串:int IndexOf(string value)int IndexOf(string value,int startIndex)int IndexOf(string value,int startIndex,int count)在上述重载形式中,其参数含义如下:Value:待定位的字符或者子串。startIndex:在总串中开始
9、搜索的起始位置。Count:在总串中从起始位置开始搜索的字符数。,13,7.1.1 静态字符串String,同IndexOf类似,LastIndexOf用于从某个位置倒序搜索在一个字符串中,某个特定的字符或子串最后一次出现的位置,其方法定义和返回值都与IndexOf相同。例如,strA(“hello”)中最后一个l字符出现的位置:Console.Write(strA.LastIndexOf(l,4,5);/3Console.Write(strA.LastIndexOf(l,2,3);/2,14,7.1.1 静态字符串String,(3)IndexOfAny/LastIndexOfAny Ind
10、exOfAny方法功能同IndexOf类似,区别在于,可以搜索在一个字符串中,出现在一个字符数组中的任意字符第一次出现的位置。,15,7.1.1 静态字符串String,下例分别在“Hello”中寻找字符数组anyof中任意一个字符第一次和最后一次出现的位置。/IndexofAny|LastIndexOfAny char anyOf=H,e,l;Console.WriteLine(strA.IndexOfAny(anyOf);/0 Console.WriteLine(strA.LastIndexOfAny(anyOf);/3 同IndexOfAny类似,LastIndexOfAny用于倒序搜索
11、最后一次出现的位置。,16,7.1.1 静态字符串String,3.格式化字符串Format方法用于创建格式化的字符串以及连接多个字符串对象。Foramt方法也有多个重载形式,最常用的为:public static string Format(string format,params object args);其中,参数format用于指定返回字符串的格式,而args为一系列变量参数。与Console.WriteLine()方法的参数设置方法类似,可以类比记忆。,17,7.1.1 静态字符串String,例如:已有定义如下:int x=12,y=34;String s=“点坐标”;/若以此字符
12、串格式”点坐标:(12,34)”输出结果。Console.WriteLine(“0:(1,2)”,s,x,y);/若只是想以此格式连接得到一个新的字符串,则可用/Format String newStr;newStr=String.Format(“0:(1,2)”,s,x,y);Console.WriteLine(newStr);/点坐标:(12,34),18,7.1.1 静态字符串String,4.连接字符串(1)Concat方法 Concat方法用于连接两个或多个字符串/Concat String newStr;newStr=String.Concat(strA,strB);Console
13、.WriteLine(newStr);/“Hello World,19,7.1.1 静态字符串String,(2)Join方法 Join方法利用一个字符串数组和一个分隔符串构造新的字符串。常用于把多个字符串连接在一起,并用一个特殊的符号来分隔开。Join方法的常用形式为:public static string Join(string separator,string values);其中,参数separator为指定的分隔符,而values用于指定所要连接的多个字符串数组。,20,7.1.1 静态字符串String,下例用“”分隔符把“Hello”和“World”连起来。/Join Stri
14、ng newStr;String strArr=strA,strB;newStr=String.Join(,strArr);Console.WriteLine(newStr);/HelloWorld,21,7.1.1 静态字符串String,(3)连接运算符“+”String支持连接运算符“+”,可以方便地连接多个字符串。例如,下例把“Hello”和“World”连接起来。/+newStr=;newStr=strA+strB;Console.WriteLine(newStr);/HelloWorld,22,7.1.1 静态字符串String,5.分隔字符串使用Split方法可以把一个整串,按照
15、某个分隔符,分裂成一系列小的字符串。例如,把整串,按照某个分隔符,分裂成一系列小的字符串。例如,把整串“HelloWorld”按照字符“”进行分裂,可以得到3个小的字符串,即“Hello”、“”(空串)和“World”。Split方法最常用的形式为:public string Split(params char separator);其中,参数separator数组包含分隔符。,23,7.1.1 静态字符串String,/Split newStr=HelloWorld;char separator=;String splitStrings=new String100;splitStrings=
16、newStr.Split(separator);int i=0;while(isplitStrings.Length)Console.WriteLine(item0:1,i,splitStringsi);i+;,输出结果如下:Item0:Hello Item1:Item2:World,24,7.1.1 静态字符串String,/若要以如下形式输入一维数组的5个元素值,如何接收数据?/1,2,3,4,5 String str;int arr=new int5;str=Console.ReadLine();/”1,2,3,4,5”String splitStrings;splitStrings=s
17、tr.Split(,);for(int i=0;isplitStrings.Length;i+)arri=int.Parse(splitStringsi);,25,7.1.1 静态字符串String,6.插入和填充字符串String类中可以用Insert方法在任意位置插入任意字符。Insert方法用于在一个字符串的指定位置插入另一个字符串,从而构造一个新的串。Insert方法最常用的为:public string Insert(int startIndex,string value);其中,参数startIndex用于指定所要插入的位置,从开始索引;value指定所要插入的字符串。,26,7.
18、1.1 静态字符串String,下例中,在“Hello”的字符“H”后面插入“World”,构造一个串“HWorldello”。/Insert String newStr;newStr=strA.Insert(1,strB);Console.WriteLine(newStr);/HWorldello,27,7.1.1 静态字符串String,7.删除和剪切字符串String类包含了删除一个字符串的方法。可以用Remove方法在任意位置删除任意长度的字符。也可以使用Trim/TrimeEnd/TrimStart方法剪切掉字符串中的一些特定字符。,28,7.1.1 静态字符串String,(1)R
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 常用 数据结构 算法 字符串
链接地址:https://www.31ppt.com/p-6570827.html