算法面試題目

面試中遇到了好多算法題目:
1>一個(gè)整數(shù)逆甜,大于0教藻,不用循環(huán)和本地變量篡悟,按照n,2n,4n,8n的順序遞增谜叹,當(dāng)值大于5000時(shí),把值按照指定順序輸出來(lái)搬葬。例:n=1237
則輸出為:1237,2474,4948,9896,9896,4948,2474,1237

這個(gè)就是典型的要你使用遞歸方法了荷腊。
簡(jiǎn)單的寫(xiě)個(gè)測(cè)試類(lèi)方法,條件什么的自己加下

public void Print(int n){
        
        System.out.print(n+",");// 先輸出n的值急凰,即輸出遞增部分
        if (n <= 5000) Print(n*2);//當(dāng)n<=5000時(shí)停局,繼續(xù)調(diào)用遞歸函數(shù)count自己,但是實(shí)參加倍
        System.out.print(n+",");//再次輸出n的值董栽,即輸出遞減部分

    }

2>將一個(gè)鍵盤(pán)輸入的數(shù)字轉(zhuǎn)化成中文輸出企孩,例如擒抛,輸入1234567 則輸出一百二十三萬(wàn)四千五百六十七

   /**
         * 把金額阿拉伯?dāng)?shù)字轉(zhuǎn)換為漢字表示,小數(shù)點(diǎn)后四舍五入保留兩位
         * 還有一種方法可以在轉(zhuǎn)換的過(guò)程中不考慮連續(xù)0的情況诊胞,然后對(duì)最終的結(jié)果進(jìn)行一次遍歷合并連續(xù)的零
         */
        public  String[] ChineseNum = new String[] { "零", "壹", "貳", "叁", "肆",
                "伍", "陸", "柒", "捌", "玖" };

        public  String NumToChinese(double num) {
            if (num > 99999999999999.99 || num < -99999999999999.99)
                throw new IllegalArgumentException(
                        "參數(shù)值超出允許范圍 (-99999999999999.99 ~ 99999999999999.99)!");
            boolean negative = false;// 正負(fù)標(biāo)號(hào)
            if (num < 0) {
                negative = true;
                num = num * (-1);
            }
            long temp = Math.round(num * 100);
            int numFen = (int) (temp % 10);// 分
            temp = temp / 10;
            int numJiao = (int) (temp % 10);// 角
            temp = temp / 10;
            // 此時(shí)temp只包含整數(shù)部分
            int[] parts = new int[20];// 將金額整數(shù)部分分為在0-9999之間數(shù)的各個(gè)部分
            int numParts = 0;// 記錄把原來(lái)金額整數(shù)部分分割為幾個(gè)部分
            for (int i = 0;; i++) {
                if (temp == 0)
                    break;
                int part = (int) (temp % 10000);
                parts[i] = part;
                temp = temp / 10000;
                numParts++;
            }
            boolean beforeWanIsZero = true;// 標(biāo)志位,記錄萬(wàn)的下一級(jí)是否為0
            String chineseStr = "";
            for (int i = 0; i < numParts; i++) {
                String partChinese = partConvert(parts[i]);
                if (i % 2 == 0) {
                    if ("".equals(partChinese))
                        beforeWanIsZero = true;
                    else
                        beforeWanIsZero = false;
                }
                if (i != 0) {
                    if (i % 2 == 0)// 億的部分
                        chineseStr = "億" + chineseStr;
                    else {
                        if ("".equals(partChinese) && !beforeWanIsZero)// 如果“萬(wàn)”對(duì)應(yīng)的
                            // part 為
                            // 0,而“萬(wàn)”下面一級(jí)不為
                            // 0影钉,則不加“萬(wàn)”,而加“零”
                            chineseStr = "零" + chineseStr;
                        else {
                            if (parts[i - 1] < 1000 && parts[i - 1] > 0)// 如果萬(wàn)的部分不為0肆汹,而萬(wàn)前面的部分小于1000大于0,則萬(wàn)后面應(yīng)該跟零
                                chineseStr = "零" + chineseStr;
                            chineseStr = "萬(wàn)" + chineseStr;
                        }
                    }
                }
                chineseStr = partChinese + chineseStr;
            }
            if ("".equals(chineseStr))// 整數(shù)部分為0,則表示為零元
                chineseStr = ChineseNum[0];
            else if (negative)// 整數(shù)部分部位0攒至,但是為負(fù)數(shù)
                chineseStr = "負(fù)" + chineseStr;
            chineseStr = chineseStr + "元";
            if (numFen == 0 && numJiao == 0) {
                chineseStr = chineseStr + "整";
            } else if (numFen == 0) {// 0分
                chineseStr = chineseStr + ChineseNum[numJiao] + "角";
            } else {
                if (numJiao == 0)
                    chineseStr = chineseStr + "零" + ChineseNum[numFen] + "分";
                else
                    chineseStr = chineseStr + ChineseNum[numJiao] + "角"
                            + ChineseNum[numFen] + "分";
            }
            return chineseStr;
        }

        // 轉(zhuǎn)換拆分后的每個(gè)部分,0-9999之間
        public  String partConvert(int partNum) {
            if (partNum < 0 || partNum > 10000) {
                throw new IllegalArgumentException("參數(shù)必須是大于等于0或小于10000的整數(shù)");
            }
            String[] units = new String[] { "", "拾", "佰", "仟" };
            int temp = partNum;
            String partResult = new Integer(partNum).toString();
            int partResultLength = partResult.length();
            boolean lastIsZero = true;// 記錄上一位是否為0
            String chineseStr = "";
            for (int i = 0; i < partResultLength; i++) {
                if (temp == 0)// 高位無(wú)數(shù)字
                    break;
                int digit = temp % 10;
                if (digit == 0) {
                    if (!lastIsZero)// 如果前一個(gè)數(shù)字不是0則在當(dāng)前漢字串前加零
                        chineseStr = "零" + chineseStr;
                    lastIsZero = true;
                } else {
                    chineseStr = ChineseNum[digit] + units[i] + chineseStr;
                    lastIsZero = false;
                }
                temp = temp / 10;
            }
            return chineseStr;
        }

直接調(diào)用即可 NumToChinese(-1002005.25);
3> 給定一個(gè)字符串溉浙,輸出本字符串中只出現(xiàn)一次并且最靠前的那個(gè)的位置馆蠕?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市吨铸,隨后出現(xiàn)的幾起案子祖秒,更是在濱河造成了極大的恐慌房维,老刑警劉巖咙俩,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件坛猪,死亡現(xiàn)場(chǎng)離奇詭異墅茉,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)啄踊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)刁标,“玉大人顿锰,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵挺勿,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我不瓶,道長(zhǎng)禾嫉,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任湃番,我火速辦了婚禮夭织,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘吠撮。我一直安慰自己尊惰,他們只是感情好讲竿,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著弄屡,像睡著了一般题禀。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上膀捷,一...
    開(kāi)封第一講書(shū)人閱讀 49,036評(píng)論 1 285
  • 那天迈嘹,我揣著相機(jī)與錄音,去河邊找鬼全庸。 笑死秀仲,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的壶笼。 我是一名探鬼主播神僵,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼覆劈!你這毒婦竟也來(lái)了保礼?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤责语,失蹤者是張志新(化名)和其女友劉穎炮障,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體坤候,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡胁赢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了铐拐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片徘键。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖遍蟋,靈堂內(nèi)的尸體忽然破棺而出吹害,到底是詐尸還是另有隱情,我是刑警寧澤虚青,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布它呀,位于F島的核電站,受9級(jí)特大地震影響棒厘,放射性物質(zhì)發(fā)生泄漏纵穿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一奢人、第九天 我趴在偏房一處隱蔽的房頂上張望谓媒。 院中可真熱鬧,春花似錦何乎、人聲如沸句惯。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)抢野。三九已至拷淘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間指孤,已是汗流浹背启涯。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留恃轩,地道東北人结洼。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像叉跛,于是被迫代替她去往敵國(guó)和親补君。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容