//-------------String类--------------

//求两个字符串的最大相同子串
/*
思路:
1.找出较短的那个字符串
2.找出短串的所有子串,使用contains函数判断是否在长串中包含了这个子串
定义一个空字符串max,始终保存目前最大的子串
3.输出max
*/
public class StringAPI {
public static void main(String args[]) {
String strA = "asdfitcastghjfghjk";
String strB = "xcitcastvbnm";
MaxStr max = new MaxStr(strA, strB);
String maxStr = max.getMaxStr();
System.out.println("最大子串:" + maxStr);
}
} class MaxStr {
String longer;
String shorter; //检出长短字符串
MaxStr(String strA, String strB) {
if (strA.length() > strB.length()) {
this.longer = strA;
this.shorter = strB;
} else {
this.longer = strB;
this.shorter = strA;
}
} //获得最大子串
/*
两层for循环就是为了找出shorter串的所有子串
假设串为 1234
实例: 外层第一次循环 1 2 3 4
1 2 3
1 2
1
          -------
外层第二次循环 2 3 4
2 3
2
-------
外层第三次循环 3 4
3
-------
外层第四次循环 4 */
public String getMaxStr() {
String max = "";
for (int i = 0; i < shorter.length(); i++) {
for (int j = shorter.length(); j >= i+1; j--) {
if (longer.contains(shorter.substring(i, j))) {
String temp = shorter.substring(i, j);
//System.out.println(temp);
if (temp.length() > max.length()) {
max = temp;//max始终存放目前已知的最大子串
}
}
}
}
return max;
}
} //对字符串中的字符进行自然顺序排序
//java中char类型占两个字节,byte类型占一个字节
public class StringAPI {
public static void main(String args[]) {
String str = "iuhewshnbjiasfoinsaojawnpjlkegh";
String strNew = mySort(str);
System.out.println(strNew); } private static String mySort(String str) {
char[] chs = str.toCharArray();//将字符串转化为char数组
Arrays.sort(chs); //Arrays类实现数组的排序和搜索等
return new String(chs);//将数组以String对象的形式返回
}
} //String的trim方法
//1.使用trim方法,2.自己写一个方法模拟trim方法
//trim方法返回一个去掉前后空格的字符串
public class StringAPI {
public static void main(String args[]) {
String str = "poaeg";
String strNew = myTrim(str);
System.out.println("+" + strNew + "+");
System.out.println("-" + str.trim() + "-");
} //注意!!这个方法要保证在全为空格,没有空格,单端为空格和双端为空格的情况下都正确
private static String myTrim(String str) {
int start = 0;
int end = str.length()-1;
//这一步start下标最多移动到最后一个元素
while (start < str.length()-1 && str.charAt(start) == ' ')
start++;
//这一步end下标最多移动到了start所指的元素的前一个元素
while (end >= start && str.charAt(end) == ' ')
end--;
return str.substring(start, end+1);
}
/*
解释:str.charAt(start) == ' '这一句是检测从前到后的第一个非空格字符的
而start < str.length()-1这一句则是专门为全是空格的情况准备的
也就是说,即便全是空格,start至多指向最后一个空格,不会出现越界 str.charAt(end) == ' '这一句是检测从后到前的第一个非空格字符的
而end >= start也是专为全为空格的情况设计的,即全为空格时,
end最多指到start之前的一个元素那里 最终,正常情况不说了
全为空格的情况下,str.substring(start, end+1)返回的是一个空字符————"";
*/
} //--------------基本类型包装类
//基本类型包装类中都有字符串与数字互转的功能
//还有最大最小值,按进制输出等等小功能 //只有一个小细节:当Integer类自动包装的时候,
//遇到Byte(-128~127)范围内的数的时候,直接公用,超出这个范围就不共用了
public class StringAPI {
public static void main(String args[]) {
Integer i = 128;
Integer j = 128;
System.out.println(i == j);//false Integer p = 127;
Integer q = 127;
System.out.println(p == q);//true
}
} //练习: //"23 9 -4 18 100 7"
//要求这串数字按照从小到大排序并生成一个数值有序的字符串
//思路:将每个数字依次提取出来到一个数组中去,排序后变成一个新字符串,最后输出出来
//我自己写的方法
public class StringAPI {
public static void main(String args[]) {
String numStr = "23 9 -4 18 100 7";
String newNumStr = mySort(numStr);
System.out.println("排序前:" + numStr);
System.out.println("排序后" + newNumStr);
} private static String mySort(String numStr) {
int beginIndex = 0;
int floatIndex = 0;
int[] arr = new int[6]; String temp = numStr.trim(); {
int i = 0;
while (floatIndex < numStr.length())
{
if (numStr.charAt(floatIndex) == ' ')
{
arr[i++] = Integer.parseInt(numStr.substring(beginIndex, floatIndex).trim());
beginIndex = floatIndex;
}
floatIndex++;
}
arr[i] = Integer.parseInt(numStr.substring(beginIndex, numStr.length()).trim());
}
Arrays.sort(arr);
StringBuffer sb = new StringBuffer();
for (int i = 0; i < arr.length; i++)
{
sb.append(Integer.toString(arr[i])+" ");
}
return sb.toString();
}
} //参考老师的方法
public class StringAPI {
private static final String SPACE = " "; public static void main(String args[]) {
String numStr = "5 3 4 8 6 2 1 7 9";
String newNumStr = mySort(numStr);
System.out.println("排序前:" + numStr);
System.out.println("排序后:" + newNumStr);
} private static String mySort(String numStr) {
//以空格为分界切割整个字符串成为几个小字符串
String[] strArrs = numStr.split(SPACE);
//获得被转化成了的int数组
int[] numArr = getNumArr(strArrs);
Arrays.sort(numArr);
//将数组中的数字拼接成一个字符串
return toString(numArr);
} //将int型数组中的数字拼接成一个字符串
private static String toString(int[] numArr) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < numArr.length; i++)
{
if (i != numArr.length-1)
sb.append(Integer.toString(numArr[i]) + " ");
else
sb.append(Integer.toString(numArr[i]));
}
return sb.toString();
}
//将字符串数组的值全部转化为数字存到int型数组中去
private static int[] getNumArr(String[] strArrs) {
int[] arr = new int[strArrs.length];
for (int i = 0; i < strArrs.length; i++)
{
arr[i] = Integer.parseInt(strArrs[i]);
}
return arr;
} }

Java的StringAPI的小练习的更多相关文章

  1. Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录)

    Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录) 作者:王可利(Star·星星) 效果图: 代码如下: class Star8 { public static void m ...

  2. Java 需要记得、了解的关键词 (Java 学习中的小记录)

    Java 需要记得.了解的关键词 (Java 学习中的小记录)     作者:王可利(Star·星星) 总结:本次随笔,仅且拿来平时翻阅记忆用

  3. java 开发面试题小整理(一)

    本篇文档将持续更新,有基础滴,也有深层次的,谢谢! 1.看下面的程序是否有问题,如果有问题,请指出并说明理由. * byte b1 = 3; * byte b2 = 4; * byte b3 = b1 ...

  4. java网络爬虫爬虫小栗子

    简要介绍: 使用java开发的爬虫小栗子,存储到由zookeeper协调的hbase中 主要过程是模拟Post请求和get请求,html解析,hbase存储 源码:https://github.com ...

  5. IT咨询顾问:一次吐血的项目救火 java或判断优化小技巧 asp.net core Session的测试使用心得 【.NET架构】BIM软件架构02:Web管控平台后台架构 NetCore入门篇:(十一)NetCore项目读取配置文件appsettings.json 使用LINQ生成Where的SQL语句 js_jquery_创建cookie有效期问题_时区问题

    IT咨询顾问:一次吐血的项目救火   年后的一个合作公司上线了一个子业务系统,对接公司内部的单点系统.我收到该公司的技术咨询:项目启动后没有规律的突然无法登录了,重新启动后,登录一断时间后又无法重新登 ...

  6. java实现简单窗体小游戏----球球大作战

    java实现简单窗体小游戏----球球大作战需求分析1.分析小球的属性: ​ 坐标.大小.颜色.方向.速度 2.抽象类:Ball ​ 设计类:BallMain—创建窗体 ​ BallJPanel—画小 ...

  7. Java之——实现微信小程序加密数据解密算法

    转载请注明出处:http://blog.csdn.net/l1028386804/article/details/79450115 一.概述 微信推出了小程序,很多公司的客户端应用不仅具有了APP.H ...

  8. Java集合,扑克牌的小项目练习

    Java集合,扑克牌的小项目练习 2小时学完了类与集合,一直二倍加跳过,集合和类的学习我觉得得多实践中去记住,光靠背,永远也背不完,学的时候记一下常用的,特殊的就行了,用的时候再查,多写代码才能会,哈 ...

  9. 用Java编写的猜拳小游戏

    学习目标: 熟练掌握各种循环语句 例题: 代码如下: // 综合案例分析,猜拳案例 // isContinue为是否开始游戏时你所输入的值 char isContinue; //y为开始,n为借宿 S ...

随机推荐

  1. [C++] Solve "Cannot run program "gdb": Unknown reason" error

    In Mac OSX, The Issue Image: 1. Build the project on Eclipse successfully. 2. Run gdb on command lin ...

  2. 【探路者】互评beta版本

    成员博客 1蔺依铭:http://www.cnblogs.com/linym762/ 2张恩聚:http://www.cnblogs.com/zej87/ 3米赫:http://www.cnblogs ...

  3. our team

    今天向大家介绍一下我们的团队,首先我们的团队叫“吉祥三宝”当然我们的三宝不是亲子关系,我们是兄弟关系,对,就是这样 下面来介绍一下我们的团队成团吧: 李奇原: 性格开朗.积极乐观.有责任心,擅长团队协 ...

  4. Xcode 6添加模板无效

    最近发现从Xcode 5拷贝来的模板在Xcode 6上是OK的,但是自己自定义的却不行,一直使用的是自定义的基类模板,最后发现原因是没有在 TemplateInfo.plist 中注册自定义的模板,注 ...

  5. 解决java图形界面label中文乱码

    第一:在你的具有main函数的类也即你应用运行的主类上点击右键,选择Run As中的Run Configurations,如下图:java,awt,中文方框,中文乱码第二,在Arguments标签下的 ...

  6. spring学习 8-面试(事务,解决线程安全)

    1.介绍一下Spring的事物管理 参考:Spring 学习7 -事务 2.Spring如何处理线程并发问题    Spring使用ThreadLocal解决线程安全问题 参考:Spring学习11- ...

  7. WCF跨时区自动转换问题

    背景:api端 用wcf做的 客户端是silverlight, 服务和消费 不是同一个时区 状况:客户端调用返回对象有个字段是datetime ,返回的时间和数据库相差好几个小时,找了很久,最后把da ...

  8. uva1391-Astronauts

    宇航员执行任务,有三个任务ABC.把宇航员按照平均年龄分成新老两组,老宇航员可以去AC,新宇航员可以取BC.宇航员之间有不能共存关系,问是否有合法的分配方案. 分析 虽然有三个任务,但每个宇航员还是只 ...

  9. bzoj3517 翻硬币

    题意 有一个n行n列的棋盘,每个格子上都有一个硬币,且n为偶数.每个硬币要么是正面朝上,要么是反面朝上.每次操作你可以选定一个格子(x,y),然后将第x行和第y列的所有硬币都翻面.求将所有硬币都变成同 ...

  10. 3.7 TCP拥塞控制

    3.7 TCP拥塞控制 在3.5.5流量控制中有,接收方通过维护一个rwnd来控制流量,本节中考虑三个问题: 第一,  一个TCP发送方如何限制它向其他连接发送流量的速率. 第二,  一个TCP发送方 ...