




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验报告四 串操作一、 实验目的:(1) 掌握串的定义、术语。(2) 掌握串的基本操作算法。(3) 掌握串的匹配算法。二、 实验内容: 1. 在常量串MyString类中,增加以下方法,并求各算法的时间复杂度。public MyString trim()/删除串中所有空格public char toCharArray()/返回字符数组public MyString toLowerCase()/返回将大写字母转换成小写字母的字符串public MyString toUpperCase()/返回将小写字母转换成大写字母的字符串public MyString replace(char old, ch
2、ar newc)/用字符newc替换串中的字符oldpublic Boolean equals(Object obj)/判断两个串是否相等public Boolean equalsIgnoreCase(String1 str) /判断两个串是否相等,忽略大小写public int compareTo(MyString str)/比较两个串大小,实现Comparable接口public int compareToIgnoreCase(MyString str) /比较两个串大小,忽略大小写public Boolean startsWith(MyString prefix)/判断prefix是否前
3、缀子串public Boolean endsWith(MyString suffix)/判断suffix是否后缀子串源代码:package Q1;import java.lang.*;public class MyString public char value;public String str;public MyString trim()/删除串中所有空格 O(N*N)for(int i=0;i<this.value.length;i+)if(this.valuei=' ')for(int j=i;j<this.value.length;j+)this.valu
4、ej=this.valuej+1;return this;public char toCharArray()/返回字符数组O(1)return this.value;public MyString toLowerCase()/返回将大写字母转换成小写字母的字符串 O(N)for(int i=0;i<this.value.length;i+)if(this.valuei>='A' && this.valuei<='Z')this.valuei=(char)(this.valuei+32);return this;public My
5、String toUpperCase()/返回将小写字母转换成大写字母的字符串 O(N)for(int i=0;i<this.value.length;i+)if(this.valuei>='a' && this.valuei<='z')this.valuei=(char)(this.valuei-32);return this;public MyString replace(char old, char newc)/用字符newc替换串中的字符old O(N)for(int i=0;i<this.value.length
6、;i+)if(this.valuei=old)this.valuei=newc;return this;public boolean equals(MyString str)/判断两个串是否相等 O(N)boolean flag=true;if(this.value.length = str.value.length)for(int i=0;i<this.value.length;i+)if(this.valuei!=str.valuei)flag=false;break;else return flag=false;return flag;public boolean equalsIg
7、noreCase(MyString str)/判断两个串是否相等,忽略大小写 O(N)boolean flag=true;if(this.value.length=str.value.length)for(int i=0;i<this.value.length;i+)if(this.valuei>='a'&&this.valuei<='z' | this.valuei>='A'&&this.valuei<='Z')if(str.valuei>='a'
8、;&&str.valuei<='z' | str.valuei>='A'&&str.valuei<='Z')if(this.valuei!=str.valuei | this.valuei+32!=str.valuei | this.valuei!=str.valuei+32)flag=false;break;else if(this.valuei!=str.valuei)flag=false;break;else if(this.valuei!=str.valuei)flag=false;bre
9、ak;else return flag=false;return flag;public int compareTo(MyString str)/比较两个串大小,实现Comparable接口 O(N)int length=0;int temp = -1;if(this.value.length >= str.value.length)length=this.value.length;else length=str.value.length;for(int i=0;i<length;i+)if(this.valuei!='0' && str.value
10、i!='0')if(this.valuei>str.valuei)temp=0;break; /0=thisif(this.valuei<str.valuei)temp=1;break; /1=strif(this.valuei!='0' && str.valuei='0')temp=0;break;if(this.valuei='0' && str.valuei!='0')temp=1;break;else temp=2; /this=strreturn temp;pu
11、blic int compareToIgnoreCase(MyString str)/比较两个串大小,忽略大小写 O(N)this.value=this.toLowerCase().value;str.value=str.toLowerCase().value;int length=0;int temp = -1;if(this.value.length >= str.value.length)length=this.value.length;else length=str.value.length;for(int i=0;i<length;i+)if(this.valuei!=&
12、#39;0' && str.valuei!='0')if(this.valuei>str.valuei)temp=0;break; /0=thisif(this.valuei<str.valuei)temp=1;break; /1=strif(this.valuei!='0' && str.valuei='0')temp=0;break;if(this.valuei='0' && str.valuei!='0')temp=1;break;else
13、temp=2; /this=strreturn temp;public Boolean startsWith(MyString prefix)/判断prefix是否前缀子串 O(N)boolean flag=true;if(this.value.length>=prefix.value.length)for(int i=0;i<prefix.value.length;i+)if(this.valuei!=prefix.valuei)flag=false;break;else flag=false;return flag;public Boolean endsWith(MyStrin
14、g suffix)/判断suffix是否后缀子串 O(N)boolean flag=true;if(this.value.length>=suffix.value.length)for(int i=0,j=this.value.length-suffix.value.length;i<suffix.value.length;i+,j+)if(this.valuej!=suffix.valuei)flag=false;break;else flag=false; return flag;2. 统计在一个串中各字符的出现次数。源代码:package Q2;public class My
15、String public static int fun(String str)char c;int account= new int128;for(int i=0;i<str.length();i+)c=str.charAt(i);accountc+;return account;public static void disp(int account)char c;for(int i=0;i<account.length ;i+)if(accounti!=0)c=(char) i;System.out.println(c+" "+accounti);Syste
16、m.out.println();public static void main(String args) String str1 = new String("Good morning!");String str2 = new String("Shanghai 2010");disp(fun(str1);disp(fun(str2);测试实例: str1=“Good morning!” str2=“Shanghai 2010”粘贴测试结果:3. 找出两个字符串中所有共同的字符。源代码:package Q3;public class MyString pub
17、lic static int account(String str)char c;int account= new int128;for(int i=0;i<str.length();i+)c=str.charAt(i);accountc=1;return account;public static int compare(int account,String str)char c;for(int i=0;i<str.length();i+)c=str.charAt(i);if(accountc=1)accountc=2;return account;public static v
18、oid disp(int account)char c;for(int i=0;i<account.length ;i+)if(accounti=2)c=(char) i;System.out.println(c);System.out.println();public static void main(String args) String str1 = new String("aaccb*be!");String str2 = new String("ab!cde*g");int account=account(str1);disp(compa
19、re(account,str2);粘贴测试结果:4. 判断一个字符串是否为一个E-mail地址。源代码:package Q4;public class MyString public static boolean decide(String str)int at_address = 0,at_account=0;int point= new int10;int point_account=0;boolean flag=true;for(int i=0;i<str.length();i+)if(!(str.charAt(0)>='A'&& str.charAt(0)<='Z' | str.charAt(0)>='a'&& str.charAt(0)<='z')return flag=false;elseif(str.charAt(i)='')at_address=i;at_account+;if(str.charAt(i)=
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025企业租赁合同模板
- 2025苏州工业园区二手房(精装修)买卖合同
- 操作作业考试题及答案七年级
- 葡萄种植课件
- 葡萄种植与养护知识培训课件
- 2025贷款抵押用担保合同
- 萨伏伊别墅课件
- 营销课件教学课件
- 2025年高考化学试题分类汇编:化学用语阿伏加德罗常数(含解析)
- 2025-2026学年人教版八年级地理上册期末评估测试卷(含答案)
- 神经外科护士进修汇报:专业提升与实践应用
- 重庆导游基础知识课件
- 建筑工地基孔肯雅热防控和应急方案
- 人教版三年级数学下册第五单元《面积》-长方形和正方形面积专项练习卷含答案
- 铜仁公积金提取管理办法
- 消防监督员业务培训课件
- 【课件】+有理数的减法(第2课时+有理数加减混合运算)(教学课件)数学人教版2024七年级上册
- 特级建筑集团资金管理副总职责
- 2025教师暑期政治培训心得体会
- (高清版)DB34∕T 486-2025 霍山石斛
- 升降平台车培训
评论
0/150
提交评论