華為機試2017

簡易壓縮算法:將全部由小寫英文字母組成的字符串,將其中連續超過兩個相同字母的部分壓縮為整個連續個數加該字母,其他部分保持不變。編寫一個解壓縮函數,判斷是否為合法壓縮后的字符串,若輸入合法則輸出解壓縮后的字符串,否則輸出字符串“!error”。

算法時間空間復雜度O(n)
思路:根據一次完整的劃分來判斷;對于該次劃分是數字開頭和字母開頭進行分類討論就行。數字開頭可能需要取到這次數字之后的兩個字母;字母開頭則需要取到這次字母之后的兩個字母。如果不需要取到最后的兩個字母,那就不會出現問題了。

import java.util.Scanner;
// 華為2016機試

public class Test {
    public static String unzip(String str){
        int numbercount=0;
        char tempchar;
        char lastcov= ' ';
        StringBuffer covchar = new StringBuffer();
        StringBuffer ret_str = new StringBuffer();
        //數字結尾不對
        if(str.charAt(str.length()-1) >= '0' && str.charAt(str.length()-1)<= '9'){
            return "error!";
        }
        
        //錯誤:aaa;32aa;3a3a;a3;1a2e
        //成功: 3a4d;2a2da;a2b;
        for(int i=0;i<str.length();i++){
            tempchar = str.charAt(i);
            //數字開頭
            if(tempchar >'0' && tempchar <='9'){
                numbercount =0;
                numbercount =numbercount *10+ (tempchar-'0');
                //讀取剩下的數字
                i = i+1;
                tempchar = str.charAt(i);               
                while(tempchar >'0' && tempchar <='9'){
                    numbercount =numbercount *10+ (tempchar-'0');
                    i++;
                    tempchar = str.charAt(i);
                }
                if(numbercount < 3){
                    return "!error";
                }
                //當前第一個字符和下一個字符是否相同
                if(i<str.length()-1 && tempchar == str.charAt(i+1)){
                    return "!error";
                }
                else{
                    if(lastcov == tempchar){
                        return "!error";
                    }
                    for(int index = 0;index<numbercount;index++){
                        ret_str.append(tempchar);
                    }
                    lastcov = tempchar;
                }
            }
            //字母開頭
            else if(tempchar >= 'a' && tempchar<='z' ){
                if(i>=str.length()-2){
                    for(;i<str.length();i++){
                        ret_str.append(str.charAt(i));
                    }
                    return ret_str.toString();
                }
                char tempchar2 = str.charAt(i+1);
                char tempchar3 = str.charAt(i+2);
                if(tempchar2 == tempchar && tempchar3 == tempchar){
                    return "!error";
                }
                else if(tempchar2 == tempchar){
                    if(lastcov == tempchar){
                        return "!error";
                    }
                    ret_str.append(tempchar);
                    ret_str.append(tempchar);
                    i=i+1;
                    lastcov = tempchar;
                }
                else if(tempchar2 != tempchar){
                    ret_str.append(tempchar);
                }
                else{
                    return "!error";
                }
            }
            //錯誤    
            else{
                return "error";
            }
        }
        return ret_str.toString();
    }
    
    public static void main(String[]  args){
        Scanner scanner = new Scanner(System.in);
        String info;
        while(scanner.hasNext())
        {
            info = scanner.nextLine();
            System.out.println(unzip(info));
        }
    }
}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 9.3.3 快速排序 ??快速排序將原數組劃分為兩個子數組,第一個子數組中元素小于等于某個邊界值,第二個子數組中的...
    RichardJieChen閱讀 1,870評論 0 3
  • linux資料總章2.1 1.0寫的不好抱歉 但是2.0已經改了很多 但是錯誤還是無法避免 以后資料會慢慢更新 大...
    數據革命閱讀 12,239評論 2 33
  • 禮堂的鐘聲響起 他牽著你的手緩緩走來 臉上洋溢的幸福恍惚了我的雙眼 這一幕幕是多么的熟悉 曾經在我夢中出現過無數次...
    秦雨希閱讀 666評論 0 1
  • 那年冬天,晚上沒有霧霾 月光和雪花照亮每一個山頭 人們懷揣各種夢想 散步在干裂的墻壁上 往前奔跑尋找位置安放心靈 ...
    郭金世閱讀 292評論 2 2
  • The best tools for men are machines. I think it is useful...
    Alice墨爾本閱讀 157評論 0 0