Java现在有一组无序字符序列: a、c、u、b、e、p、f、z.按字母顺序进行升序排列。
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java现在有一组无序字符序列: a、c、u、b、e、p、f、z.按字母顺序进行升序排列。相关的知识,希望对你有一定的参考价值。
现在有一组无序字符序列: a、c、u、b、e、p、f、z.按字母顺序进行升序排列,现在要往此字符序列中插入一个新的字符,要求插入之后字符序列仍保持有序。本人是Java新手,代码需简单
String[] nums= "a","c","u","b","e","p","f","z";Scanner input = new Scanner(System.in);
System.out.print("原字符序列:");
String num="";
for(int i=0;i<nums.length;i++)
num=nums[i];
System.out.print(num+"\t");
Arrays.sort(nums);
System.out.print("\n升序排序后:");
for(String sum:nums)
System.out.print(sum+"\t");
/*System.out.print("\n逆序输出为:");
for(int i=nums.length-1;i>=0;i--)
num=nums[i];
System.out.print(num+"\t");
*/
System.out.print("\n请输入新插入的字符:");
String zifu=input.next();
int index=nums.length-1;//插入的数据下标
for(int i=0;i<nums.length;i++)
//字符串比较大小,相当于zifu-nums[i]<0;
if(zifu.compareTo(nums[i])<0)
index=i;
break;
System.out.print("插入字符的下标是:"+index);
System.out.print("\n插入后的字符序列是:");
//扩充数组
String[] newnums = new String[nums.length+1];
//数组拷贝
System.arraycopy(nums, 0, newnums, 0, nums.length);
nums = newnums;
for(int j=nums.length-1;j>index;j--)
nums[j]=nums[j-1];
nums[index]=zifu;
for(String aum:nums)
System.out.print(aum+"\t");
参考技术A 你好,有很多关于Java字母,数字排序的案例,可以百度 Java字母排序看相关的博客。能够自我提升,不同的方式不同的效果。希望能够帮助你 参考技术B
/**
* 2015年5月12日下午12:24:39
*
* @author season TODO 获取百度知道财富
*
*/
public class CharacterMethod
/**
* bubble2Up TODO 使用冒泡排序对字符串数组升序排序
*
* @param yourArr
* 目标字符串数组
*/
public void bubble2Up(char[] yourArr)
for (int index = 0; yourArr != null && index < yourArr.length; index++)
for (int j = 0; j < yourArr.length - index - 1; j++)
if (yourArr[j] > yourArr[j + 1])
char temp = yourArr[j];
yourArr[j] = yourArr[j + 1];
yourArr[j + 1] = temp;
/**
* insertInto TODO 在相应的位置插入一个字符,插入之后,顺序不变
*
* @param yourArr
* 目标数组
* @param tagChar
* 插入目标字符
* @return char[] 返回新的字符串数组
*/
public char[] insertInto(char[] yourArr, char tagChar)
char[] temp = new char[yourArr.length + 1];
int flag = 0, index;
for (index = 0; index < yourArr.length; index++)
if (tagChar >= yourArr[index])
temp[index] = yourArr[index];
else if (flag == 0)
temp[index] = tagChar;
flag = 1;
else
temp[index] = yourArr[index - 1];
temp[index] = yourArr[index - 1];
return temp;
/**
* display TODO 遍历字符串数组里面的所有元素
*
* @param charArr
* 需要显示的字符串数组
*/
public void display(char[] charArr)
System.out.println();// 换行输出
for (int index = 0; index < charArr.length; index++)
System.out.print(" " + charArr[index]);
public static void main(String[] args)
CharacterMethod cmd = new CharacterMethod();// 声明对象
char[] yourArr = 'a', 'c', 'u', 'b', 'e', 'p', 'f', 'z' ;// 赋初值
cmd.display(yourArr);// 排序之前显示原始字符数组
cmd.bubble2Up(yourArr);// 冒泡排序
cmd.display(yourArr);// 显示排序之后的数组
cmd.display(cmd.insertInto(yourArr, 'k'));// 显示插入之后的字符串数组
java学习第十四天
1:正则表达式(理解) (1)就是符合一定规则的字符串 (2)常见规则 A:字符 x 字符 x。举例:‘a‘表示字符a \\ 反斜线字符。 \n 新行(换行)符 (‘\u000A‘) \r 回车符 (‘\u000D‘) B:字符类 [abc] a、b 或 c(简单类) [^abc] 任何字符,除了 a、b 或 c(否定) [a-zA-Z] a到 z 或 A到 Z,两头的字母包括在内(范围) [0-9] 0到9的字符都包括 C:预定义字符类 . 任何字符。我的就是.字符本身,怎么表示呢? \. \d 数字:[0-9] \w 单词字符:[a-zA-Z_0-9] 在正则表达式里面组成单词的东西必须有这些东西组成 D:边界匹配器 ^ 行的开头 $ 行的结尾 \b 单词边界 就是不是单词字符的地方。 举例:hello world?haha;xixi E:Greedy 数量词 X? X,一次或一次也没有 X* X,零次或多次 X+ X,一次或多次 X{n} X,恰好 n 次 X{n,} X,至少 n 次 X{n,m} X,至少 n 次,但是不超过 m 次 (3)常见功能:(分别用的是谁呢?) A:判断功能 String类的public boolean matches(String regex) B:分割功能 String类的public String[] split(String regex) C:替换功能 String类的public String replaceAll(String regex,String replacement) D:获取功能 Pattern和Matcher Pattern p = Pattern.compile("a*b"); Matcher m = p.matcher("aaaaab"); find():查找存不存在 group():获取刚才查找过的数据 (4)案例 A:判断电话号码和邮箱 B:按照不同的规则分割数据 C:把论坛中的数字替换为* D:获取字符串中由3个字符组成的单词 2:Math(掌握) (1)针对数学运算进行操作的类 (2)常见方法(自己补齐) A:绝对值 B:向上取整 C:向下取整 D:两个数据中的大值 E:a的b次幂 F:随机数 G:四舍五入 H:正平方根 (3)案例: A:猜数字小游戏 B:获取任意范围的随机数 3:Random(理解) (1)用于产生随机数的类 (2)构造方法: A:Random() 默认种子,每次产生的随机数不同 B:Random(long seed) 指定种子,每次种子相同,随机数就相同 (3)成员方法: A:int nextInt() 返回int范围内的随机数 B:int nextInt(int n) 返回[0,n)范围内的随机数 4:System(掌握) (1)系统类,提供了一些有用的字段和方法 (2)成员方法(自己补齐) A:运行垃圾回收器 B:退出jvm C:获取当前时间的毫秒值 D:数组复制 5:BigInteger(理解) (1)针对大整数的运算 (2)构造方法 A:BigInteger(String s) (3)成员方法(自己补齐) A:加 B:减 C:乘 D:除 E:商和余数 6:BigDecimal(理解) (1)浮点数据做运算,会丢失精度。所以,针对浮点数据的操作建议采用BigDecimal。(金融相关的项目) (2)构造方法 A:BigDecimal(String s) (3)成员方法: A:加 B:减 C:乘 D:除 E:自己保留小数几位 7:Date/DateFormat(掌握) (1)Date是日期类,可以精确到毫秒。 A:构造方法 Date() Date(long time) B:成员方法 getTime() setTime(long time) C:日期和毫秒值的相互转换 案例:你来到这个世界多少天了? (2)DateFormat针对日期进行格式化和针对字符串进行解析的类,但是是抽象类,所以使用其子类SimpleDateFormat A:SimpleDateFormat(String pattern) 给定模式 yyyy-MM-dd HH:mm:ss B:日期和字符串的转换 a:Date -- String format() b:String -- Date parse() C:案例: 制作了一个针对日期操作的工具类。 8:Calendar(掌握) (1)日历类,封装了所有的日历字段值,通过统一的方法根据传入不同的日历字段可以获取值。 (2)如何得到一个日历对象呢? Calendar rightNow = Calendar.getInstance(); 本质返回的是子类对象 (3)成员方法 A:根据日历字段得到对应的值 B:根据日历字段和一个正负数确定是添加还是减去对应日历字段的值 C:设置日历对象的年月日 (4)案例: 计算任意一年的2月份有多少天?
以上是关于Java现在有一组无序字符序列: a、c、u、b、e、p、f、z.按字母顺序进行升序排列。的主要内容,如果未能解决你的问题,请参考以下文章