泡LeetCode的日子-查詢無效交易

題目

題解

package com.killshadow.leetcode;

import java.util.*;

public class InvalidTransactions {
    public static void main(String[] args) {
        InvalidTransactions invalidTransactions = new InvalidTransactions();
        List<String[]> strings = new ArrayList<>();
        strings.add(new String[]{"alice,20,800,mtv", "alice,50,100,beijing"});
        strings.add(new String[]{"alice,20,800,mtv","alice,50,1200,mtv"});
        strings.add(new String[]{"bob,689,1910,barcelona", "alex,696,122,bangkok", "bob,832,1726,barcelona",
                "bob,820,596,bangkok", "chalicefy,217,669,barcelona", "bob,175,221,amsterdam"});
        strings.add(new String[]{"bob,627,1973,amsterdam", "alex,387,885,bangkok", "alex,355,1029,barcelona",
                "alex,587,402,bangkok", "chalicefy,973,830,barcelona", "alex,932,86,bangkok", "bob,188,989,amsterdam"});

        for (String[] in : strings) {
            System.out.println(invalidTransactions.invalidTransactions(in).toString());
        }

    }

    public List<String> invalidTransactions(String[] transactions) {
        List<String> inValid = new ArrayList<>();
        List<Transaction> sameTrans = new ArrayList<>();

        for (String trans : transactions) {

            String[] info = trans.split(",");

            Transaction temp = new Transaction(info[0], Integer.valueOf(info[1]),
                    Integer.valueOf(info[2]), info[3]);

            if (temp.amount > 1000 && !inValid.contains(trans)) {
                inValid.add(trans);
            }

            for (Transaction tmp : sameTrans) {
                if (tmp.name.equals(temp.name) && !tmp.city.equals(temp.city) &&
                        (Math.abs(tmp.time - temp.time) <= 60)) {
                    if (!inValid.contains(trans)) {
                        inValid.add(trans);
                    }
                    if (!inValid.contains(tmp.toString())) {
                        inValid.add(tmp.toString());
                    }
                }
            }

            sameTrans.add(temp);

        }

        return inValid;
    }

    private class Transaction {
        String name;
        int time;
        int amount;
        String city;
        private Transaction(String name, int time, int amount, String city) {
            this.name = name;
            this.time = time;
            this.amount = amount;
            this.city = city;
        }

        public String toString() {
            return name + "," + time + "," + amount + "," + city;
        }
    }
}
Result
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蚊夫,一起剝皮案震驚了整個(gè)濱河市奠伪,隨后出現(xiàn)的幾起案子捌蚊,更是在濱河造成了極大的恐慌骏令,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異凭疮,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)串述,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門执解,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人纲酗,你說我怎么就攤上這事衰腌。” “怎么了觅赊?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵右蕊,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我吮螺,道長(zhǎng)饶囚,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任鸠补,我火速辦了婚禮萝风,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘莫鸭。我一直安慰自己,他們只是感情好横殴,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布被因。 她就那樣靜靜地躺著,像睡著了一般衫仑。 火紅的嫁衣襯著肌膚如雪梨与。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天文狱,我揣著相機(jī)與錄音粥鞋,去河邊找鬼。 笑死瞄崇,一個(gè)胖子當(dāng)著我的面吹牛呻粹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播苏研,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼等浊,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了摹蘑?” 一聲冷哼從身側(cè)響起筹燕,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后撒踪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體过咬,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年制妄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了掸绞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡忍捡,死狀恐怖集漾,靈堂內(nèi)的尸體忽然破棺而出畜普,到底是詐尸還是另有隱情费封,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布募逞,位于F島的核電站凌埂,受9級(jí)特大地震影響驱显,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜瞳抓,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一埃疫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧孩哑,春花似錦栓霜、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至丛晌,卻和暖如春仅炊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背澎蛛。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工抚垄, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人谋逻。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓呆馁,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親毁兆。 傳聞我的和親對(duì)象是個(gè)殘疾皇子智哀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345