题目链接:https://leetcode-cn.com/problems/invalid-transactions/

如果出现下述两种情况,交易 可能无效:

交易金额超过 ¥1000
或者,它和另一个城市中同名的另一笔交易相隔不超过 60 分钟(包含 60 分钟整)
每个交易字符串 transactions[i] 由一些用逗号分隔的值组成,这些值分别表示交易的名称,时间(以分钟计),金额以及城市。

给你一份交易清单 transactions,返回可能无效的交易列表。你可以按任何顺序返回答案。

提示:

transactions.length <= 1000
每笔交易 transactions[i] 按 "{name},{time},{amount},{city}" 的格式进行记录
每个交易名称 {name} 和城市 {city} 都由小写英文字母组成,长度在 1 到 10 之间
每个交易时间 {time} 由一些数字组成,表示一个 0 到 1000 之间的整数
每笔交易金额 {amount} 由一些数字组成,表示一个 0 到 2000 之间的整数

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/invalid-transactions
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解:

用一个内部类来描述一个交易的信息,将所有交易记录加入到数组中,遍历数组判断记录是否有效,时间复杂度:O(n^2)

 
    private class Trade {
        private String s;
        private String name;
        private int time;
        private int money;
        private String city;
        private boolean valid;

        public Trade(String s, String name, int time, int money, String city) {
            super();
            this.s = s;
            this.name = name;
            this.time = time;
            this.money = money;
            this.city = city;
            this.valid = this.money > 1000 ? false : true;
        }

        @Override
        public String toString() {
            return s;
        }

        private boolean invalid(Trade o) {
            return this.name.equals(o.name) && !this.city.equals(o.city)
                    && Math.abs(this.time - o.time) <= 60;
        }
    }

    public List<String> invalidTransactions(String[] transactions) {
        List<String> result = new ArrayList<String>();
        List<Trade> trades = new ArrayList<Trade>();
//        1.使用Pattern和Matcher(比split慢)

//        Pattern p = Pattern.compile("([a-z]{1,10}),(\\d{1,4}),(\\d{1,4}),([a-z]{1,10})");
        for (String s : transactions) {
//            Matcher m = p.matcher(s);
//            if (m.find()) {
//                Trade t = new Trade(s, m.group(1), Integer.valueOf(m.group(2)),
//                        Integer.valueOf(m.group(3)), m.group(4));
//                trades.add(t);
//            }

//            valueOf会调用parseInt得到int值封装成Integer对象,而parseInt则是返回int值

//            2.使用String的split方法
            String[] split = s.split(",");
            Trade t = new Trade(s, split[0], Integer.parseInt(split[1]), Integer.parseInt(split[2]),
                    split[3]);
            trades.add(t);
        }
        for (int i = 0; i < trades.size(); i++) {
            Trade iTrade = trades.get(i);
            if (!iTrade.valid) {
                continue;
            }
            for (int j = 0; j < trades.size(); j++) {
                if (i == j) {
                    continue;
                }
                Trade jTrade = trades.get(j);
                if (iTrade.invalid(jTrade)) {
                    // 外部类能访问内部类的私有属性
                    iTrade.valid = false;
                    jTrade.valid = false;
                }
            }
        }
        for (Trade t : trades) {
            if (!t.valid) {
                result.add(t.toString());
            }
        }
        return result;
    }

  

通过这题,我尝试了使用Pattern和Matcher,知道了valueOf和parseInt的区别,发现外部类可以访问内部类的私有属性,以前从来没研究过。

最新文章

  1. 1-Spark高级数据分析-第一章 大数据分析
  2. 输入一个数组,求最小的K个数
  3. bind() live()和delegate 区别
  4. [译]Canvas的基本用法
  5. SpringMVC实战
  6. python 最佳入门实践
  7. ubuntu下安装gradle
  8. POJ 2386 Lake Counting (水题,DFS)
  9. c基础补充
  10. java List 去重(两种方式)
  11. Programming Concepts
  12. Android四大图片缓存(Imageloader,Picasso,Glide,Fresco)原理、特性对比
  13. Angular绑定数据时转义html标签
  14. Android Studio实现Service AIDL
  15. scala函数
  16. 旧版本firefox添加扩展addons的地址
  17. Linux中python3,django,redis以及mariab的安装
  18. oracle查询查询出某字段为空后前台不显示的小测试1
  19. 时序扩展的UML状态图的测试用例生成研究
  20. Confluence 6 目录中的数据库

热门文章

  1. 使用PowerShell 测试DNS
  2. 最小环-Floyd
  3. net core Webapi 总目录
  4. spark任务调度模式,动态资源分配
  5. Groovy语法基础
  6. 入门MySQL——用户与权限
  7. 使用注解的Hibernate one-to-many映射
  8. Istio 太复杂?KubeSphere基于Ingress-Nginx实现灰度发布
  9. 缓存系列-Redis入门教程
  10. 9043Markdown常用用法