[Java]5个java编程实例

单纯记录一下学习过程

  • 1.模拟一个trim方法,去除字符串两端的空格
  • 2.将一个字符串反转,将字符串中指定部分进行反转。例如将“abcdefg”反转为“abfedcg”
  • 3.获取一个字符串在另一个字符串中出现的次数
  • 比如,获取“ab”在“abkkcadkaebfkabkskab”中出现的次数
  • 4.获取两个字符串中最大的相同子串。比如:
  • str1=“abcwerthelloyuiodef”;str2=“cvhellobnm”
  • 5.对字符串中字符进行自然顺序排序
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/*
 * 1.模拟一个trim方法,去除字符串两端的空格
 * 2.将一个字符串反转,将字符串中指定部分进行反转。例如将“abcdefg”反转为“abfedcg”
 * 3.获取一个字符串在另一个字符串中出现的次数
 * 比如,获取“ab”在“abkkcadkaebfkabkskab”中出现的次数
 * 4.获取两个字符串中最大的相同子串。比如:
 * str1="abcwerthelloyuiodef";str2="cvhellobnm"
 * 5.对字符串中字符进行自然顺序排序
 * 
 */
public class StringDemo {
public static void main(String[] args) {
	String str="    abc  de  ";
	String str2="      ";
	String str3=myTrim(str2);
	String str1=myTrim(str);
	System.out.println(str1);
	System.out.println(str3);//健壮性不好,数组下标越界
	
	String str4="abcdefg";
	String str5=reverseString(str4,2,5);
	String str6=reverseString1(str4, 2, 5);
	System.out.println(str5);
	System.out.println(str6);
	
	int  i=getTime("abkkcadkaebfkabkskab", "ab");
	System.out.println(i);
	
	String str7=getMaxSubString("abcwerthelloyuiodef", "cvhellobnm");
	//不严谨,可能出现多个相同子串,当"abcwerthelloyuiodef", "abcwecvhellobnm",出现abcwe
	System.out.println(str7);
	
	List<String> str8=getMaxSubString1("abcwerthelloyuiodef", "abcwecvhellobnm");
	System.out.println(str8);
	
	String str9="asdnbvysc";
	String str10=sort(str9);
	System.out.println(str10);
			
}
//4.获取两个字符串中最大的相同子串。
public static String getMaxSubString(String str1,String str2) {
	String maxStr=(str1.length()>str2.length())?str1:str2;
	String minStr=(str1.length()<str2.length())?str1:str2;
	int len=minStr.length();
	for(int i=0;i<len;i++) {//i每加1,子串str2="cvhellobnm"就减1,如:当i等于1时,str2="cvhellobn"或str2="vhellobnm",所以内部需要一个循环
		for(int x=0,y=len-i;y<=len;x++,y++) {
			String str=minStr.substring(x, y);//子串cvhellobn
			if(maxStr.contains(str)) {
				return str;
			}
		}
	}
	return null;
}
//4.改进(获取两个字符串中最大的相同子串)
public static List<String> getMaxSubString1(String str1,String str2) {
	String maxStr=(str1.length()>str2.length())?str1:str2;
	String minStr=(str1.length()<str2.length())?str1:str2;
	int len=minStr.length();
	List<String> list=new ArrayList<>();
	for(int i=0;i<len;i++) {//i每加1,子串str2="cvhellobnm"就减1,如:当i等于1时,str2="cvhellobn"或str2="vhellobnm",所以内部需要一个循环
		for(int x=0,y=len-i;y<=len;x++,y++) {
			String str=minStr.substring(x, y);//子串cvhellobn
			if(maxStr.contains(str)) {
				list.add(str);
			}
		}
		if(list.size()!=0) {
			return list;
		}
	}
	return null;
}
	//1.模拟一个trim方法,去除字符串两端的空格
	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--;
		}
		return str.substring(start,end+1);//substring为左闭右开
	}
	
	//2.将一个字符串反转,将字符串中指定部分进行反转。例如将“abcdefg”反转为“abfedcg”
	public static  String reverseString(String str,int start,int end) {
		char[] c=str.toCharArray();//转换成字符数组进行操作
		return reverseArray(c,start,end);
	}
	public static String reverseArray(char[] c,int start,int end) {
		for(int i=start,j=end;i<j;i++,j--) {
			char temp=c[i];
			c[i]=c[j];
			c[j]=temp;
		}
		//字符数组转换成字符串
		return new String(c);
	}
	//方法二:将字符串分为3部分.例如将“abcdefg”分为“ab”“cdef”“g”,建立一个子串先取出“ab”,再将
	//“cdef”逆序取出,添加在子串后面,最后添加“g”
	//考虑使用StringBuffer将此算法进行优化
	public static  String reverseString1(String str,int start,int end) {
		String str1=str.substring(0,start);
		for(int i=end;i>=start;i--) {
			char c=str.charAt(i);
			str1+=c;
			}
		str1+=str.substring(end+1);//左闭右开
		return str1;
	}
	//3.获取一个字符串在另一个字符串中出现的次数,判断str2在str1中出现的次数
	public static int getTime(String str1,String str2) {
		int count=0;
		int len;
		while((len=str1.indexOf(str2))!=-1) {//判断str1中是否出现str2,若出现,则记录出现的位置
			count++;
			str1=str1.substring(len+str2.length());//以str2的长度+str2第一次出现的位置,为子串开始的位置
		}
		return count;
	}
	//5.对字符串中字符进行自然顺序排序
	//先转换成字符数组,再使用已有的字符数组的排序方法,最后在转换回来
	public static String sort(String str) {
		char[] c=str.toCharArray();
		Arrays.sort(c);
		return new String(c);
	}
	}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目录如下: ==================================== 实例1 HelloWorld 实例10 创建一个窗体 实例100 上传文件 实例11 按扭 实例12 复选框 实例13 复合下拉列表 实例14 下拉列表 实例15 选项卡 实例16 对话框 实例17 文件对话框 实例18 使用HTML语言 实例19 菜单 实例2 java流程控制 实例20 工具栏 实例21 内部窗体 实例22 分割一个面板 实例23 滑动杆 实例24 颜色过滤器 实例25 表格 实例26 基本图形绘制 实例27 绘制波图形 实例28 图片的处理 实例29 绘制指针时钟 实例3 数组数据操作 实例30 三围立方框 实例31 三围立方体 实例32 标准输入输出 实例33 读写文件(字节) 实例34 读写文件(字符操作) 实例35 获取文件信息 实例36 目录操作 实例37 读取随机文件 实例38 操作EXECL文件 实例39 生成PDF文件 实例4 矢量对象操作 实例40 压缩和解压文件 实例41 执行系统命令 实例42 获取计算机名称和IP地址 实例43 一对简单的服务器和客户端 实例44 多线程服务器 实例45 使用SMTP协议发送邮件 实例46 使用SMTP协议接收邮件 实例47 使用JAVAMAIL发送邮件 实例48 使用JAVAMAIL接收邮件 实例49 获取URL文本 实例5 哈希表和枚举器 实例50 一个简单的WEB服务器 实例51 数据报通讯:聊天吧 实例52 使用ODBC连接数据库 实例53 加载JDBC驱动 实例54 使用语句预处理 实例55 可滚动结果集 实例56 数据库元数据 实例57 结果集元数据 实例58 调用存储过程 实例59 事务处理 实例6 类的继承 实例60 继承THREAD 实例62 多线程 实例63 线程组群 实例64 线程间通讯 实例65 线程同步 实例66 线程控制 实例67 线程优先级 实例68 使用DOM解析XML 实例69 使用SAX解析XML 实例7 接口和抽象类 实例70 使用JDOM解析XML 实例71 使用JDOM操作XML 实例72 欢迎进入APPLET世界 实例73 传递参数 实例74 监测鼠标事件 实例75 监测键盘事件 实例76 在APPLET中使用SWING 实例77 应用JAR包 实例78 播放声音 实例79 一个简单的SERVLET 实例8 类的标识和访问控制 实例80 使用SERVLET获取客户表单 实例81 SERVLET读取COOKIE数据 实例82 SERVLET读取SESSION数据 实例83 一个简单的JSP 实例84 JSP处理表单提交 实例85 JSP连接数据库 实例86 JSP使用数据连接池 实例87 JSP+BEAN的应用 实例88 JSP+BEAN连接数据库 实例89 读取属性文件 实例9 异常的捕获和实现自己的异常类 实例90 上传文件 实例91 读取浏览器文件头 实例92 无状态会话EJB 实例93 有状态会话EJB 实例94 容器管理实体EJB 实例95 BEAN自管理实体EJB 实例96 消息驱动BEAN 实例97 简单的STRUTS 实例98 信息表单提交 实例99 连接数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值