出租车问题

来源:互联网 发布:声波发生器软件 编辑:程序博客网 时间:2024/04/27 13:48

出租车问题

在未来,出租汽⻋公司已经采⽤⾃动驾驶汽⻋来开展出租⻋业务。哒哒出⾏就是这样⼀家公司,为了提⾼⽤
户体验,公司需要设计⼀款软件来统计提醒⻋辆保养情况。汽⻋保养分为每⼀万公⾥保养和定期保养两种,
另外汽⻋除保养之外,达到⼀定条件,则会进⼊报废。
每1万公⾥保养提醒规则如下:
汽⻋每跑1万公⾥(含)就要保养⼀次,距离1万公⾥还差500公⾥(含)的时候就要开始提醒
为了简化规则,不需考虑未及时保养或者重复保养的场景,以及不需考虑上次实际保养时间和⼤修时间

定期保养提醒规则如下:

3年以下⻋辆每12个⽉定期保养⼀次
3年及以上⻋辆每6个⽉定期保养⼀次
若⻋辆有⼤修,则每3个⽉就需要定期保养⼀次
定期保养全部提前⼀个⽉开始提醒,直到需要保养的那天(含)为⽌
在计算⽉份时,只需考虑⽉份,不需考虑⽇期,如07⽉31⽇和8⽉1⽇之间也差⼀个⽉,在计算年份时,
只需要考虑年份,不需考虑⽉和⽇,如2016年12⽉31⽇和2017年1⽉1⽇也认为相差⼀年。
为了简化规则,不需考虑未及时保养或者重复保养的场景,以及不需考虑上次实际保养时间和⼤修时间

车辆报废规则如下:

⼀般⻋辆6年(据购买⽇期加6*365=2190天)开始报废
若⻋辆有⼤修,报废年限降为3年(据购买⽇期加3*365=1095天)
报废⻋辆提前⼀个⽉开始提醒(提前⼀个⽉提醒,不需要考虑⽇,⽐如 03⽉28⽇ ⻋辆报废,那
么 02⽉01⽇ 即可开始提醒)
ThoughtWorks2018校园招聘作业题⽬——出租⻋
说明
家庭作业部分

注意:

如果⻋辆已经开始提醒报废或已经报废,则⽆需保养
如果⻋辆同时需要每1万公⾥保养和定期保养,则按每1万公⾥保养计
请编写程序,提醒公司相关⼈员需要保养和报废的⻋辆。
程序输⼊为字符串,其格式严格规定如下:
⽂本的第⼀⾏表示提交⽇期,识别⻋辆状况时以该⽇期作为当前⽇期。该⾏格式
为 SubmitDate: {提交⽇期 yyyy-MM-dd} ,如 SubmitDate: 2030/09/01
随后每⼀⾏代表⼀辆汽⻋。汽⻋的各种信息使⽤ | 字符进⾏分隔,其排列顺序为
{⻋牌号}|{购买⽇期}|{品牌名称}|{⽬前运⾏公⾥数}|{有⽆⼤修} ;
购买⽇期的格式为 yyyy/MM/dd (如 2026/02/18 );
⽬前运⾏公⾥数为整数,不带有除数字之外的其他符号;
有⽆⼤修的格式为 ‘T’ 或者 ‘F’ ,前者表示有⼤修,后者表示⽆⼤修;

范例:

SubmitDate: 2030/09/01
CAR0001|2025/04/05|Porsche|10000|F
CAR0002|2029/10/14|Porsche|9000|F
CAR0003|2026/08/17|Porsche|13000|F
CAR0004|2027/11/01|BYD|23000|T
CAR0005|2027/01/11|BYD|19500|F
CAR0006|2029/07/01|Audi|10001|T
CAR0007|2028/04/19|Ford|9800|F
CAR0008|2027/07/10|Ford|15000|T
CAR0009|2024/10/22|Ford|90300|F
对于前⾯的输⼊,相应的输出范例为:
程序输⼊
程序输出

Reminder

  • Time-related maintenance coming soon…
    Audi: 1 (CAR0006)
    Porsche: 1 (CAR0002)
  • Distance-related maintenance coming soon…
    BYD: 1 (CAR0005)
    Ford: 1 (CAR0007)
    Porsche: 1 (CAR0001)
  • Write-off coming soon…
    BYD: 1 (CAR0004)
    Ford: 1 (CAR0009)
    其中
    Time-related maintenance 指需要提醒定期保养的⻋辆
    Distance-related maintenance 指需要提醒每1万公⾥保养的⻋辆
    Write-off 指需要提醒报废的⻋辆
    每⼀组中的⻋辆按照品牌升序排序(品牌第⼀个字⺟均为⼤写)
    输⼊
    SubmitDate: 2030/09/01
    CAR0001|2025/04/05|Porsche|10000|F
    CAR0002|2029/10/14|Porsche|9000|F
    CAR0003|2026/08/17|Porsche|13000|F
    CAR0004|2027/11/01|BYD|23000|T
    CAR0005|2027/01/11|BYD|19500|F
    CAR0006|2029/07/01|Audi|10001|T
    CAR0007|2028/04/19|Ford|9800|F
    CAR0008|2027/07/10|Ford|15000|T
    CAR0009|2024/10/22|Ford|90300|F
    输出
    测试⽤例⼀

Reminder

  • Time-related maintenance coming soon…
    Audi: 1 (CAR0006)
    Porsche: 1 (CAR0002)
  • Distance-related maintenance coming soon…
    BYD: 1 (CAR0005)
    Ford: 1 (CAR0007)
    Porsche: 1 (CAR0001)
  • Write-off coming soon…
    BYD: 1 (CAR0004)
    Ford: 1 (CAR0009)
    输⼊
    SubmitDate: 2050/05/01
    CAR0001|2044/05/01|Volkswagen|65535|F
    CAR0002|2044/05/03|BMW|100001|F
    CAR0003|2047/05/02|Mercedes-Benz|37789|T
    CAR0004|2047/05/03|Honda|59908|T
    CAR0005|2049/12/10|Peugeot|49999|F
    CAR0006|2046/11/15|Jeep|2000|F
    CAR0007|2046/11/16|Jeep|5000|F
    输出

Reminder

  • Time-related maintenance coming soon…
    Jeep: 2 (CAR0006, CAR0007)
  • Distance-related maintenance coming soon…
    Peugeot: 1 (CAR0005)
  • Write-off coming soon…
    BMW: 1 (CAR0002)
    Honda: 1 (CAR0004)
    测试⽤例⼆

代码块

 * Created by misfortune on 2017/10/15. */import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.*;class Taxi{    private String carId;    private String purchaseDate;    private String brand;    private int currentRunningKilometers;    private boolean hasHeavyMaintenance;    private int statment=7;    Taxi(String str){        String []sourceStrArray=str.split("\\|");        carId=sourceStrArray[0];        purchaseDate=sourceStrArray[1];        brand=sourceStrArray[2];        currentRunningKilometers=Integer.parseInt(sourceStrArray[3]);        hasHeavyMaintenance=sourceStrArray[4].equals("T");    }    public String getCarId() {return carId;}    public void setCarId(String carId) {this.carId = carId;}    public String getPurchaseDate() {return purchaseDate;}    public void setPurchaseDate(String purchaseDate) {this.purchaseDate = purchaseDate;}    public String getBrand() {return brand;}    public void setBrand(String brand) {this.brand = brand;}    public int getCurrentRunningKilometers() {return currentRunningKilometers;}    public void setCurrentRunningKilometers(int currentRunningKilometers) {this.currentRunningKilometers = currentRunningKilometers;}    public boolean isHasHeavyMaintenance() {return hasHeavyMaintenance;}    public void setHasHeavyMaintenance(boolean hasHeavyMaintenance) {this.hasHeavyMaintenance = hasHeavyMaintenance;}    public int getStatment() {return statment;}    public void setStatment(int statment) {this.statment = statment;}    public void display(){        System.out.println(getCarId()+"|"+getPurchaseDate()+"|"+getBrand()+"|"+getCurrentRunningKilometers()+"|"+isHasHeavyMaintenance()+"|"+statment);    }    public void isWriteOff(String currentTime)throws ParseException{        //判断是否已经报废        Calendar calendar1=Calendar.getInstance();        Calendar calendar2=Calendar.getInstance();        SimpleDateFormat sdf=new SimpleDateFormat("yyyy/MM/dd");            calendar1.setTime(sdf.parse(purchaseDate));            calendar2.setTime(sdf.parse(currentTime));        if(hasHeavyMaintenance!=false){            calendar1.add(Calendar.DATE,+1095);        }else calendar1.add(Calendar.DATE,+2190);        if(calendar1.after(calendar2)){            statment=6;//车辆状态为未报废,是否需要提醒保修、是否即将过期未知        } else statment=0;//车辆状态为已报废    }    public void isWillWriteOff(String currentTime)throws ParseException{        if(statment==6){            Calendar calendar1=Calendar.getInstance();            Calendar calendar2=Calendar.getInstance();            SimpleDateFormat sdf=new SimpleDateFormat("yyyy/MM/dd");            calendar1.setTime(sdf.parse(purchaseDate));            calendar2.setTime(sdf.parse(currentTime));            if(hasHeavyMaintenance!=false){                calendar1.add(Calendar.DATE,+1095);            }else calendar1.add(Calendar.DATE,+2190);            if(calendar1.get(Calendar.YEAR)==calendar2.get(Calendar.YEAR)&&calendar1.get(Calendar.MONTH)==calendar2.get(Calendar.MONTH)){                    statment=1;            }else {                calendar1.add(Calendar.MONTH,-1);                if(calendar1.get(Calendar.YEAR)==calendar2.get(Calendar.YEAR)&&calendar1.get(Calendar.MONTH)==calendar2.get(Calendar.MONTH)){                    statment=1;                     }                }            }        }    public void timeRelated(String currentTime)throws ParseException{        if(statment==6){                Calendar calendar1=Calendar.getInstance();                Calendar calendar2=Calendar.getInstance();                SimpleDateFormat sdf=new SimpleDateFormat("yyyy/MM/dd");                calendar1.setTime(sdf.parse(purchaseDate));                calendar2.setTime(sdf.parse(currentTime));                if(hasHeavyMaintenance!=false){                    for(int i=0;i<12;i++){                        calendar1.add(Calendar.MONTH,+2);                        if(calendar1.get(Calendar.MONTH)==calendar2.get(Calendar.MONTH)){                            statment=2;                        }                    }                }else {                    calendar1.add(Calendar.YEAR,+3);                    if(calendar1.after(calendar2)){                        calendar1.add(Calendar.YEAR,-3);                        for(int i=0;i<6;i++){                            calendar1.add(Calendar.MONTH,+12);                            if(calendar1.get(Calendar.YEAR)==calendar2.get(Calendar.YEAR)){                                calendar1.add(Calendar.MONTH,-1);                                if(calendar1.get(Calendar.MONTH)==calendar2.get(Calendar.MONTH)){                                    statment=2;                                    break;                                }                            }                        }                    }else{                        calendar1.add(Calendar.YEAR,-3);                        for(int i=0;i<12;i++){                            calendar1.add(Calendar.MONTH,+6);                            if(calendar1.get(Calendar.YEAR)==calendar2.get(Calendar.YEAR)){                                if(calendar1.get(Calendar.MONTH)==calendar2.get(Calendar.MONTH)&&calendar1.after(calendar2)){                                    statment=2;                                    break;                                }else {                                    calendar1.add(Calendar.MONTH,-1);                                    if(calendar1.get(Calendar.MONTH)==calendar2.get(Calendar.MONTH)&&calendar1.after(calendar2)){                                        statment=2;                                        break;                                    }                                }                            }                        }                    }                }            }        }    public void distanceRelated(){        if (statment==6) {            if(currentRunningKilometers%10000+500>=10000||currentRunningKilometers%10000==0)statment=3;            //仅需要一万里公里保养提醒        }else if(statment==2){            if(currentRunningKilometers%10000+500>=10000||currentRunningKilometers%10000==0)statment=3;            //当定期保养和一万里保养同时需要进行,按一万公里保养记        }    }}public class TaxiMaintenance {    public static void main(String[] args)throws ParseException{        Scanner sc=new Scanner(System.in);        String currentTime=(sc.nextLine().replaceAll("SubmitDate: ",""));        List<Taxi> taxiList=new ArrayList<Taxi>();        String str=sc.nextLine();        if(str.equals(""))sc.close();        while(!str.equals("")){            taxiList.add(new Taxi(str));            str=sc.nextLine();        }        System.out.print(taxiList.size());        Taxi []wait=new Taxi[taxiList.size()];        String brand[]=new String[taxiList.size()];        for(int i=0;i<wait.length;i++){            wait[i]=taxiList.get(i);            brand[i]=wait[i].getBrand();            wait[i].isWriteOff(currentTime);            wait[i].isWillWriteOff(currentTime);            wait[i].timeRelated(currentTime);            wait[i].distanceRelated();            wait[i].display();        }        List list=Arrays.asList(brand);        Set set=new HashSet(list);        String brand1[]=(String[]) set.toArray(new String[0]);        Arrays.sort(brand1,String.CASE_INSENSITIVE_ORDER);        System.out.println("Reminder\n==================\n* Time-related maintenance coming soon...");        for(int i=0;i<brand1.length;i++){            int cout=0;            String ot1=new String();            String ot2=new String();            String ot3=new String();            String ot=new String();            for(int j=0;j<wait.length;j++){                if(wait[j].getBrand().equals(brand1[i])&&wait[j].getStatment()==2){                    cout++;                    if(cout==1) {                        ot1 = brand1[i] + ": " ;                        ot2=" (" + wait[j].getCarId();                    }else if(cout>1){                        ot3=","+wait[j].getCarId();                    }                }                ot=ot1+cout+ot2+ot3;            }                if(!ot.equals("0"))System.out.println(ot+")");        }        System.out.println("* Distance-related maintenance coming soon...");        for(int i=0;i<brand1.length;i++){            int cout=0;            String ot1=new String();            String ot2=new String();            String ot3=new String();            String ot=new String();            for(int j=0;j<wait.length;j++){                if(wait[j].getBrand().equals(brand1[i])&&wait[j].getStatment()==3){                    cout++;                    if(cout==1) {                        ot1 = brand1[i] + ": " ;                        ot2=" (" + wait[j].getCarId();                    }else if(cout>1){                        ot3=","+wait[j].getCarId();                    }                }                ot=ot1+cout+ot2+ot3;            }            if(!ot.equals("0"))System.out.println(ot+")");        }        System.out.println("* Write-off coming soon...");        for(int i=0;i<brand1.length;i++){            int cout=0;            String ot1=new String();            String ot2=new String();            String ot3=new String();            String ot=new String();            for(int j=0;j<wait.length;j++){                if(wait[j].getBrand().equals(brand1[i])&&wait[j].getStatment()==1){                    cout++;                    if(cout==1) {                        ot1 = brand1[i] + ": " ;                        ot2=" (" + wait[j].getCarId();                    }else if(cout>1){                        ot3=","+wait[j].getCarId();                    }                }                ot=ot1+cout+ot2+ot3;            }            if(!ot.equals("0"))System.out.println(ot+")");        }        sc.close();    }}
原创粉丝点击