代码训练营——String
2016-04-30 11:04
204 查看
一、模拟一个trim方法,去除字符串两端的空格。
思路: 1,判断字符串第一个位置是否是空格,如果是继续向下判断,直到不是空格为止。 结尾处判断空格也是如此。 2,当开始和结尾都判断到不是空格时,就是要获取的字符串。
public static String myTrim(String str) { int start = 0; int end = str.length()-1; while(start<=end&&str.charAt(start)==' ') start++; while(start<=end&&str.charAt(end)==' ') end--; String s1 = str.substring(start,end+1); return s1; }
二、将一个字符串进行反转。
将字符串中指定部分进行反转,”abcdefg”;abfedcg思路:
1,曾经学习过对数组的元素进行反转。
2,将字符串变成数组,对数组反转。
3,将反转后的数组变成字符串。
4,只要将或反转的部分的开始和结束位置作为参数传递即可。
public static String reverseString(String str,int start,int end) { char[] arr = str.toCharArray(); reverse(arr,start,end); return new String(arr); } public static String reverseString(String str) { //char[] arr = str.toCharArray(); //reverse(arr); return new String(reverseString(str,0,str.length()-1)); } private static void reverse(char[] arr,int start,int end) { while(start<end) { swap(arr,start,end); end--; start++; } } private static void reverse(char[] arr) { int begin = 0; int end = arr.length-1; char temp; while(begin<end) { swap(arr,begin,end); end--; begin++; } } private static void swap(char[] array,int begin,int end) { char temp; temp = array[begin]; array[begin] = array[end]; array[end] = temp; }
三,获取一个字符串在另一个字符串中出现的次数。
"abkkcdkkefkkskk" 思路: 1,定义个计数器。 2,获取kk第一次出现的位置。 3,从第一次出现位置后剩余的字符串中继续获取kk出现的位置。 每获取一次就计数一次。 4,当获取不到时,计数完成。
public static int getSubCount(String str,String key) { int count =0; int index =0; while((index=str.indexOf(key))!=-1) { count++; str = str.substring(index+key.length()); sop("str-> "+str); } return count; }
public static int getSubCount2(String str,String key) { int count = 0; int index = 0; while((index=str.indexOf(key,index))!=-1) { index =index+key.length(); sop("index:"+index); count++; } return count; }
public static void sop(String str) { System.out.println(str); }
四、获取两个字符串中最大相同子串。
第一个动作:将短的那个串进行长度一次递减的子串打印。“abcwerthelloyuiodef”
“cvhellobnm”
思路:
1,将短的那个子串按照长度递减的方式获取到。
2,将每获取到的子串去长串中判断是否包含,
如果包含,已经找到!。
public static String getMaxString(String s1,String s2) { String max = (s1.length()>s2.length())?s1:s2; String min= (s1==max)?s2:s1; sop("max="+max); sop("min"+min); for(int i=0;i<min.length();i++ ) { for(int j=0,k=min.length()-i;k<min.length();j++,k++) { String s = min.substring(j,k); if(max.contains(s)) //if(max.indexOf(s)!=-1) { sop(s); return s; } } } return " "; }
关于String的总结
1.获取
1.1 字符串中包含的字符数,也就是字符串的长度。int length();获取长度
1.2 根据位置获取位置上的某个字符。
char charAt(int index);
1.3 根据字符获取该字符在字符串中位置
int indexOf(int ch);返回的是ch在字符串中第一次出现的位置。
int indexOf(int ch,int fromIndex):从fromIndex指定位置开始,获取ch在字符串中出现的位置;
int indexOf(String str);返回的是str在字符串中第一次出现的位置。
int indexOf(String str,int fromIndex):从fromIndex指定位置开始,获取str在字符串中出现的位置;
int lastIndexOf(int ch):
2.判断
2.1 字符串中是否包含某一个字串。boolean contains(str)
特殊之处:indexOf(str):可以索引str第一次出现位置,如果返回-1。表示该str不在字符串中存在。所以,也可以用于
对指定判断是否包含。
if(str.indexOf(“aa”)!=-1)而且该方法既可以判断,又可以获取出现的位置。
2.2 字符中是否有内容。
boolean isEmpty();
2.3 字符中是否是以指定内容开头。
boolean startsWith(str);
2.4 字符串是否是以指定内容结尾。
boolean endsWith(str);
2.5判断字符串内容是否相同,复写了Object类中的equals方法;
boolean equals(str);
2.6 判断内容是否相同,并忽略大小写
boolean equalsIgnoreCase();
3.转换
3.1 将字符数组转成字符串 构造函数:String(char[]) String(char[],offset,count):将字符数组中的一部分转成字符串。 静态方法:static String copyValueOf(char[]); static String copyValueOf(char[] data,int offset,int count) static String valueOf(char[]) 3.2 将字符串转为字符数组 char[] toCharArray()
3.3 将字节数组转成字符串
String(byte[])
String(byte[],offset,count);将字节数组中的一部分转成字符串。
3.4 将字符串转成字节数组
byte[] getBytes();
3.5 将基本数据类型转成字符串
static String valueOf(int)
static String valueOf(double)
//3+”“; //String.valueOf(3);
特殊:字符串和字节数组在转换工程中,是可以指定编码表的。
3.6 将字符串和字节数组在转换过程中,是可以指定编码表的
4.替换
String replace(oldchar,newchar);
5.切割
String[] split(regex);
6.子串,获取字符串中的一部分。
String substring(begin); String substring(begin,end);
7.转换,去除空格,比较。
7.1 将字符串转成大写或小写 String toUpperCase(); String toLowerCase(); 7.2 将字符串两端的多个空格去除 String trim(); 7.3 对两个字符串进行自然顺序的比较 int compareTo(String);
部分实例
class Demo { public static void simulate_trim() { String s1 = " abc hello"; sop(s1); int i = 0; while(s1.charAt(i)==' '&&i<s1.length()) { i++; } if(i<s1.length()) { s1.substring(1,s1.length()); } } public static void method_7() { String s = " Hello java i love you !"; String s1 ="aad"; String s2 = "aba"; sop(s.toLowerCase()); sop(s.toUpperCase()); sop(s.trim()); sop(s1.compareTo(s2)); } public static void method_sub() { String s = "abcdefg"; sop(s.substring(2));//从指定位置到结尾,如果角标不存在,会出现字符串角标越界异常。 sop(s.substring(2,4));//包含头不包含尾 sop(s.substring(0,s.length())); } public static void method_split() { String s = "zhanghhsanlisihhwangwu"; String[] arr = s.split("hh"); for(int x = 0;x<arr.length;x++) { sop(arr[x]); } } public static void method_replace() { String s = "Hello Alex!"; //String s1 = s.replace('w','n'); //如果要替换的字符不存在,返回的还是原串。 String s1 = s.replace("Alex","world"); sop("s="+s+"\ns1="+s1); } public static void method_trans() { char[] arr={'a','b','c','d','e','f'}; String s = new String(arr,1,3); sop("s="+s); String s1 ="zscdfks"; char[] chs = s1.toCharArray(); for(int x=0;x<chs.length;x++) { sop("ch="+chs[x]); } } public static void method_is() { String str = "ArrayDemo.java"; //判断文件名称是否是Array单词开头 sop(str.startsWith("Array")); //判断文件名称是否是.java的文件。 sop(str.endsWith(".java")); //判断文件中是否包含Demo sop(str.contains("Demo")); } public static void method_get() { String str = "abcadaef"; sop(str.length()); sop(str.charAt(4)); sop(str.indexOf('m',3)); sop(str.lastIndexOf("a")); } public static void main(String[] args) { //simulate_trim(); method_7(); //method_sub(); //method_split(); //method_replace(); //method_trans(); //method_is(); //method_get(); /* String s1 = "abc"; String s2 = new String("abc"); String s3 = "abc"; System.out.println(s1==s2); System.out.println(s1==s3); */ } public static void sop(Object obj) { System.out.println(obj); } }
相关文章推荐
- c++ 如何用一个函数实现两个字符串的比较
- C++文件和流
- 常用代码段
- 常用代码段
- Code Hunt 题解 05-08 (Java)
- FTP连接报错530 Permission denied解决方法
- C语言中的atoi函数的实现
- [C++]详解异常处理(Exception Handling) 及标准库异常处理类
- PHP经典算法计算两个日期的差数
- 【JAVA】hashcode() & equals()
- qt 链接sqlite数据库
- c++ 智能指针用法详解
- Raspberry Pi 配置笔记二
- Eclipse上安装GIT插件EGit及使用
- Eclipse:The resource 'project name'is not accessible for lauching
- myeclipse项目导入到eclipse中缺jar包
- Git/Github的使用以及与Eclipse的整合
- Struts2注解配置之@Results和@Result
- C语言中结构体的直接赋值
- c++:template使用中的常见报错