博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
华为编程题:字符串排序
阅读量:4581 次
发布时间:2019-06-09

本文共 1172 字,大约阅读时间需要 3 分钟。

编写一个程序,将输入字符串中的字符按如下规则排序。

规则1:英文字母从A到Z排列,不区分大小写。

      如,输入:Type 输出:epTy

规则2:同一个英文字母的大小写同时存在时,按照输入顺序排列。

    如,输入:BabA 输出:aABb

规则3:非英文字母的其它字符保持原来的位置。

    如,输入:By?e 输出:Be?y

样例:

    输入:

   A Famous Saying: Much Ado About Nothing(2012/8).

    输出:

   A aaAAbc dFgghh: iimM nNn oooos Sttuuuy (2012/8).

解题

先把字母链接起来,在插入其他字符

连接字母的依据是遍历字母

import java.util.*;public class Main{    public static void main(String [] args){        Scanner in = new Scanner(System.in);        String str="";        StringBuffer sb;        while(in.hasNext()){            str = in.nextLine();            sb = new StringBuffer();            for(int i =0;i<=25;i++){                char ch = (char)('a' + i);                for(int j=0;j< str.length();j++){                    if( str.charAt(j) == ch || str.charAt(j) == ch - 32)                        sb.append(str.charAt(j));                }            }            for(int i =0;i
= 'a' && m <= 'z') || (m >= 'A' && m <= 'Z')) { continue; } else { sb.insert(i, m); } } System.out.println(sb.toString()); } }}

 

转载于:https://www.cnblogs.com/theskulls/p/5346380.html

你可能感兴趣的文章