【面试系列】把一个字符串里除了大小写字母以外的所有东西都去掉,然后都变成小写,之后按顺序排序

4 篇文章 0 订阅

联德威的面试编程第一题:把一个字符串里除了大小写字母以外的所有东西都去掉,然后都变成小写,之后按从a到z的顺序排序


要求是不能用系统自带的函数实现,要自己编写。所以就用ASC码表,a=A+32

排序使用的冒泡,简单

public class Test01 {
	
	public static void main(String[] args) {
		System.out.println(sort(getString()));
	}
	
	static String a="sdaASH%iAGA rG$vAG;o3#yrqi br@lAHks813tgpHre iyt12qtgf";
	
	public static String getString(){
		StringBuffer str = new StringBuffer();
		for(int i=0;i<a.length();i++){
			if(a.charAt(i)>=97 && a.charAt(i)<=122 )
				str.append(a.charAt(i));
			else if(a.charAt(i)>=65 && a.charAt(i)<=90)
				str.append((char)(a.charAt(i)+32));
		}
		return str.toString();
	}

	public static String sort(String str){
		char[] c = new char[str.length()];
		for(int i=0;i<str.length();i++){
			c[i]=str.charAt(i);
		}
		char[] d=bubbleSort(c, c.length);
		StringBuffer sb = new StringBuffer();
		for(int j=0;j<d.length;j++){
			sb.append(d[j]);
		}
		return  sb.toString();	
	}
	
	public static char[] bubbleSort(char[] c,int n){
		int i,j,flag;
		for (i = 1; i<=n-1; i++) {
			flag=0;
			for (j = n-1; j >=i ; j--)
				if(((Comparable)c[j]).compareTo((Comparable)c[j-1])<0){
					char x = c[j];c[j]=c[j-1];c[j-1]=x;
					flag=1;
				}
			if(flag==0) break;
		}
		return c;
	}
}


运行结果是:

aaaaaabdefggggghhhiiiklopqqrrrrssstttvyy

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值