Codility测试-Mobile billing logs filter - Java Stream案例

Codility有一个测试,对电信商寄来的手机账单进行过滤和校验,以确认没有错误。Java 8 Stream解决此类问题比较简单,请看近似代码:

import java.io.;
import java.util.
;
import java.util.stream.Stream;
import java.util.stream.Collectors;
class Solution {
public static class Log{ // 产生一个通话记录class
public String phone;
public int durInt;
public String getPhone(){return phone;}
public int getDuration(){return durInt;}
Log(String d, String p){
phone = p;
try{
String[] t = d.split("?; //电信商发来的通话记录分隔符
durInt = Integer.parseInt(t[0])x3600+Integer.parseInt(t[1])x60+Integer.parseInt(t[2]); // 电信商计费规则:每次通话小于5分钟,每秒3分钱;
if (durInt<300)
durInt = durIntx3;
else
durInt = (durInt+59)/60x500; // 大于等于5分钟,每分钟5块钱,不够一分钟按一分钟计费。
} catch (Exception ex){
durInt = 0;
}
}
}
public static void main(String[] args) {
String str = “00:04:01 416-345-1213|01:05:00 416-345-6368|00:05:00 647-677-8130|00:05:00 905-946-6197|00:05:00 416-345-6368|00:06:01 905-944-3200”; // 固定格式的通话记录
String[] logs = str.split("\|"); // 需要转义
List logList = Stream.of(logs).map(l -> {
String durStr = l.substring(0,8);
String phoneNum = l.substring(9);
Log aLog = new Log(durStr,phoneNum); // 将每条记录转为Object
return aLog;
}).sorted((l1,l2) -> l1.phone.compareTo(l2.phone)*(-1)).peek(p->{
System.out.println(p.phone+" “+p.durInt);
}).collect(Collectors.toList()); // 生成所有object的List
Map<String, Integer> sum = logList.stream().collect(
Collectors.groupingBy(Log::getPhone, Collectors.summingInt(Log::getDuration))); // 按电话号码进行费用汇总
System.out.println(sum);
List logList = logM.entrySet().stream().map(a->a.getKey()+” “+a.getValue()).sorted((a1,a2)->{
String[] lStr1 = a1.split(” “);
String p1 = lStr1[0];
int c1 = Integer.parseInt(lStr1[1]);
String[] lStr2 = a2.split(” ");
String p2 = lStr2[0];
int c2 = Integer.parseInt(lStr2[1]);
if (c1==c2)
return p1.compareTo(p2);
else
return c1>c2?-1:1;
}).peek(System.out::println).collect(Collectors.toList()); //每月最高费用的电话记录免费
System.out.println("The final charging list(cents) is "+retList); //最终结果
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值