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.按字母顺序进行升序排列。的主要内容,如果未能解决你的问题,请参考以下文章

Gson - 反序列化未知类

数组3

算法项集匹配模式

python 字典

在Java中重复排列数组

机器学习 信息熵