1. 程式人生 > 其它 >對6-8次PTA題目集總結

對6-8次PTA題目集總結

前言:

通過了前幾次的大作業的洗禮後,來到這一次的大作業,感覺還是比較簡單的。沒有什麼無從下手的地方,仿照著PTA給出的類圖很快就有個初步模板了,後面自己慢慢除錯就可以解決大部分問題了。

在後續的學習中又接觸到了面向物件的七大原則,我接下來會總結一下作業中也會用到並且自我感覺比較重要的原則給出自己的理解。

 關於面向物件的原則

面向物件有著七大基本原則,分別是開閉原則,單一職責原則,里氏代換原則,迪米特原則,介面隔離原則,依賴倒置原則和合成複用原則。接下來給我出認為最重要的兩個原則,也就是前兩個原則。

開閉原則:

這裡給出的開閉並不是所謂門的開關閉合,而是對擴充套件開放,對修改閉合。對模組的功能進行開放,需要增加功能只需要新增加一個新的類去接上,不需要去修改已經完成的類的程式碼。根據前面的講解可以得知,面向物件的可複用設計的基石,其他設計原則是實現開閉原則的手段和工具。

單一職責原則:

單一職責的職責可以就簡單理解為行為,類是一個物體,物體的行為分為不同的職責,將不同的職責分開裝入不同的類之中,負責所單一的職責來實現單一職責原則。這樣做的好處有:類的複雜度降低,可讀性提高,可維護性提高,擴充套件性提高,降低變更引起的風險。

這兩種原則在接下來的PTA大作業中給出的類圖中都有針對性的進行設計。

PTA中遇到的bug和問題

此處就類舉一下寫作業中碰到的問題與bug

PTA6-8(電信計費):

1.精度問題。

2.計費方式錯誤計算導致的錯誤。

3.類的錯誤或遺漏設計導致的錯誤。

4.對電話號碼進行matches錯誤設計導致的錯誤。

總結: bug來源主要來自以下四點:
1.對計費方式理解的欠缺,一開始沒有理解到一分鐘多1s也算作2分鐘。 2.考慮不周到,很多情況沒有考慮到。 3.自己對題目的觀察理解不夠透徹,導致健壯性的不完善。 4.不小心寫錯。  

 程式碼分析

(程式碼量太大這裡不給出全程式碼,部分題目給出關鍵的程式碼,只給出類圖和耦合度以及對題目的分析)

PTA6
  7-1  電信計費系列1-座機計費
  類圖: 耦合度:

程式碼:

在給出類圖的類後,新增加了判斷類,來對輸入資料進行判斷以及接收。

class InputDeal {
    
    public int checkInput(String s)
    {
        int returnNum = 0;
        String[] input = s.split(" ");
        //輸入u-xxxx的情況
        if(input.length == 2) {
            if (input[0].matches("^u-[0-9]{11,13}$")) {
                Integer r = Integer.parseInt(input[1]);
                if(r>=0 && r<=2)
                    returnNum = 1;                                
            }
        }
        //輸入t-xxxx的情況
        else if(input.length == 6) {
            if(judgeMent_t(input))
                returnNum = 2;
        }
        return returnNum;
    }
    public boolean judgeMent_t(String[] input) {
        if (valiDateDate(input[2]))
            if (valiDateDate(input[4]))
                if (valiDateTime(input[3]))
                    if (valiDateTime(input[5]))
                        if (input[0].matches("[t]-0791[0-9]{7,8}"))
                            if (input[1].matches(".[0-9]{9,11}")) {
                                return true;    
                            }
        return false;                
    }
    public boolean valiDateTime(String s) {
        if( s.matches("^([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$") ) {
            return true;
        }
            return false;
    }
    public boolean valiDateDate(String s) {
        if(!s.matches("\\d{4}+[\\.]\\d{1,2}+[\\.]\\d{1,2}"))
            return false;
        String[] ss = s.split("\\.");
        //分出年月日
        int year = Integer.parseInt(ss[0]);
        int month = Integer.parseInt(ss[1]);
        int day = Integer.parseInt(ss[2]);
        
        if(month<1 && month>12)
            return false;
        int[] monthArray = new int[]{0,31,28,31,30,31,30,31,31,30,31,30,31};
        
        if( isRunNian(year) )
            monthArray[3] = 29;
        
        int monthLength = monthArray[month];
        if (day < 1 || day > monthLength) {
            return false;
        }
        return true;
    }
    /**
     * @判斷是否是閏年(是返回true,否返回false)
     */
    public boolean isRunNian(int year) {
        return ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0);
    }
    /**
     * @輸入使用者資訊
     */
    public void InputUser(ArrayList<User> users,String s) {
        //u-079186300001 0
        User newUser = new User();
        String[] input = s.split(" ");
        newUser.setNumber( input[0].substring(2) );
        //檢查是否有號碼相同,相同則結束本次輸入
        for( User user : users) {
            if( user.getNumber().equals(newUser.getNumber()) )
                return;
        }
        int mode = Integer.parseInt( input[1] );
        //選擇計費型別
        switch (mode) {
            case 0 :  newUser.setChargeMode( new LandlinePhoneCharging() );break;
            default :
        }
        
        users.add(newUser);
    }
    /**
     * @輸入使用者的通訊資訊
     */
    public void InputRecord(ArrayList<User> users,String s) {
        //t-079186330022 058686330022 2022.1.3 10:00:25 2022.1.3 10:05:11
        String[] input = s.split(" ");
        String callingNumber = input[0].substring(2);
        String answerNumber = input[1];
//        if(!callingNumber.matches("[079[0-9]|0701]+[0-9]{7,8}"))
//            return;
        CallRecord callRecord = new CallRecord(input);
        
        User calus = null;
        User ansus = null;
        //選擇正確的使用者
        for( User us : users ) {
            if( us.getNumber().equals(callingNumber) )
                calus = us;
            if( us.getNumber().equals(answerNumber) )
                ansus = us;
            if(calus!=null && ansus!=null)
                break;
        }
        //打電話使用者記錄
        if (calus != null) {
            if (callRecord.getCallType() == 1)
                calus.getUserRecords().addCallingInCityRecords(callRecord);
            else if (callRecord.getCallType() == 2)
                calus.getUserRecords().addCallingInProvinceRecords(callRecord);
            else
                calus.getUserRecords().addCallingInLandRecords(callRecord);
        }
        //接聽使用者記錄
        if (ansus != null) {
            if (callRecord.getCallType() == 1)
                ansus.getUserRecords().addAnswerInCityRecords(callRecord);
            else if (callRecord.getCallType() == 2)
                ansus.getUserRecords().addAnswerInProvinceRecords(callRecord);
            else
                ansus.getUserRecords().addAnswerInLandRecords(callRecord);
        }
    }

}

PTA7
  7-1 電信計費系列2-手機+座機計費
  類圖:

耦合度:

程式碼:

對輸入類檢測輸入的修改

public int checkInput(String s)
    {
        if (s.matches("[u]-0791[0-9]{7,8}\\s[0]") || s.matches("[u]-1[0-9]{10}\\s[1]")) {
            return 1;
        } else if (s.matches("(([t]-0791[0-9]{7,8}\\s" + "0[0-9]{9,11}\\s)|"
                + "([t]-0791[0-9]{7,8}\\s" + "1[0-9]{10}\\s" + "0[0-9]{2,3}\\s)|"
                + "([t]-1[0-9]{10}\\s" + "0[0-9]{2,3}\\s" + "0[0-9]{9,11}\\s)|"
                + "([t]-1[0-9]{10}\\s" + "0[0-9]{2,3}\\s" + "1[0-9]{10}\\s" + "0[0-9]{2,3}\\s))"
                
                + "((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]|[0-9][1-9][0-9]{2}|[1-9][0-9]{3})\\.(((0?[13578]|1[02])\\.(0?"
                + "[1-9]|[12][0-9]|3[01]))|(([469]|11)\\.([1-9]|[12][0-9]|30))|(2\\.([1-9]|[1][0-9]|2[0-8]))))|((("
                + "[0-9]{2})([48]|[2468][048]|[13579][26])|(([48]|[2468][048]|[3579][26])00))\\.2\\.29))"
                + "\\s([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])\\s"
                + "((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]|[0-9][1-9][0-9]{2}|[1-9][0-9]{3})\\.((([13578]|1[02])\\.("
                + "[1-9]|[12][0-9]|3[01]))|(([469]|11)\\.([1-9]|[12][0-9]|30))|(2\\.([1-9]|[1][0-9]|2[0-8]))))|((("
                + "[0-9]{2})([48]|[2468][048]|[13579][26])|(([48]|[2468][048]|[3579][26])00))\\.2\\.29))"
                + "\\s([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])")) {
            return 2;
        }
        return 0;
    }

這裡由於需要考慮的情況有些多,所以直接照搬了網上的程式碼。

直接在CallRecord中加入的判斷語句

/**
 * @通話記錄類
 * @父類:通訊記錄抽象類CommunicationRecord
 */
class CallRecord extends CommunicationRecord {
    private Date startTime; //通話的起始時間
    private Date endTime; //通話的結束時間
    private String callingAddressAreaCode; //撥號地點的區號
    private String answerAddressAreaCode; //接聽地點的區號
    public CallRecord() {
        
    }
    public CallRecord(String[] input) {
        super();
        char type = input[0].charAt(0);
        input[0] = input[0].substring(2);
        String d1=null,t1=null,d2=null,t2=null;
        if(type == 't')
        switch ( input.length ) {
            case 6: d1=input[2];t1=input[3];d2=input[4];t2=input[5];
                    callingAddressAreaCode = input[0].substring(0,4);
                    answerAddressAreaCode = input[1].substring(0,4);
                    break;
            case 7:    d1=input[3];t1=input[4];d2=input[5];t2=input[6];
                if(input[0].charAt(0) != '0') {
                    if(input[2].length() == 10) {
                        answerAddressAreaCode = input[2].substring(0,3);
                    } else {
                        answerAddressAreaCode = input[2].substring(0,4);
                    }
                    callingAddressAreaCode = input[1];
                }
                else {
                    if(input[0].length() == 10) {
                        callingAddressAreaCode = input[0].substring(0,3);
                    } else {
                        callingAddressAreaCode = input[0].substring(0,4);
                    }
                    answerAddressAreaCode = input[2];
                }
                break;
            case 8:    d1=input[4];t1=input[5];d2=input[6];t2=input[7];
                    callingAddressAreaCode = input[1];
                    answerAddressAreaCode = input[3];
                    break;
            default : break;
        }
        else if(type=='m'){
            
        }
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy.MM.dd HH:mm:ss", Locale.getDefault());
        try {
            startTime = simpleDateFormat.parse(d1 + " " + t1);
            endTime = simpleDateFormat.parse(d2 + " " + t2);
        } catch (ParseException e) {
        }
    }
    /**
     * @return String 前面表示撥打電話(1表示市內,2表示省內,3表示省外)後面表示接聽電話(1表示市內,2表示省內,3表示省外)
     */
    public String getCallType() {
//        System.out.println(callingAddressAreaCode+" "+answerAddressAreaCode);
        String s = "";
        if (callingAddressAreaCode.equals("0791")) {
            s = s.concat("1");
        }
        else if (callingAddressAreaCode.matches("^079[023456789]$") || callingAddressAreaCode.equals("0701")) {
            s = s.concat("2");
        }
        else {
            s = s.concat("3");
        }
        
        if (answerAddressAreaCode.equals("0791")) {
            s = s.concat("1");
        }
        else if (answerAddressAreaCode.matches("^079[023456789]$") || answerAddressAreaCode.equals("0701")) {
            s = s.concat("2");
        }
        else {
            s = s.concat("3");
        }
        return s;
    }
    public Date getStartTime() {
        return startTime;
    }
    
    public void setStartTime(Date startTime) {
        this.startTime = startTime;
    }
    
    public Date getEndTime() {
        return endTime;
    }
    
    public void setEndTime(Date endTime) {
        this.endTime = endTime;
    }
    
    public String getCallingAddressAreaCode() {
        return callingAddressAreaCode;
    }
    
    public void setCallingAddressAreaCode(String callingAddressAreaCode) {
        this.callingAddressAreaCode = callingAddressAreaCode;
    }
    
    public String getAnswerAddressAreaCode() {
        return answerAddressAreaCode;
    }
    
    public void setAnswerAddressAreaCode(String answerAddressAreaCode) {
        this.answerAddressAreaCode = answerAddressAreaCode;
    }
    /**
     * @return double型別的通話時長(單位s)
     */
    public double getTalkTime() {
        return (endTime.getTime() - startTime.getTime())/1000;
    }
}

PTA8:

7-1 電信計費系列3-簡訊計費

類圖:

耦合度:

 因為每道題目所需要更改的部分基本都一至,按照要求進行相應的修改即可,並且最後一次很簡單,這邊也不給出程式碼了

對電信計費系列的分析: 這次電信計費系列還是很簡單的,按照給定的類圖進行相應的設計後即可實現大體上的功能,需要注意的地點一共有三點,一個就是輸入的檢測,檢測是User還是被打電話的人,其中的判斷在PTA中佔有的分值也是挺高的。第二點就是在設計計費方式的方面,要注意到多1s多記1分鐘的。最後一點其實是在檢測計費方式的方面,以為t-後的電話型別可能分很多種,也就是要考慮自己的位置和對面的位置所相對應出相應的計費方式,這一點非常重要,其中我也因為考慮不周到踩到了不少的坑。總之這次pta只要將這幾點考慮周到應該是沒什麼太大問題的,將第一次的pta6設計完後,後面幾次只要做相應的修改還是比較簡單的

 總結與感想:

三次大作業雖然難度不大,但也讓我學到了很多。從自己硬寫高複雜度的爛程式碼,到從類圖中提取有效資訊,按照類圖來寫高質量程式碼,並由此更深刻地體會到面向物件的魅力、面向物件程式設計所帶來的簡潔、程式碼修改的方便,java的學習讓我程式設計時的思路更加清晰、明朗。

        期末考試的順利結束,意味著這個學期的java學習正式告一段落。這是本學期的最後一篇java部落格,也是java課的最後一個任務。我在這個學期的java學習過程中,遇到了大大小小的困難,被一次次地搞心態,但是最後還是挺過來了。學習嘛,不遇到幾次困難你永遠不知道自己幾斤幾兩,也永遠不會進步。java課程的結束,並不意味著java學習的結束。技術發展日新月異,我們在短短一學期內所學到的,永遠只是java宇宙的冰山一角。其它的學科也一樣。學習也不能侷限於學校裡學的知識。學習不是一蹴而就的過程,更要的是博識多學、堅持不懈。千淘萬漉雖辛苦,吹盡狂沙始到金。人生也是這樣,克服所遇到的困難,讓自己閃現出金子般的光芒!最後,在此感謝老師同學們對我java學習所提供的幫助!

前言:

通過了前幾次的大作業的洗禮後,來到這一次的大作業,感覺還是比較簡單的。沒有什麼無從下手的地方,仿照著PTA給出的類圖很快就有個初步模板了,後面自己慢慢除錯就可以解決大部分問題了。

在後續的學習中又接觸到了面向物件的七大原則,我接下來會總結一下作業中也會用到並且自我感覺比較重要的原則給出自己的理解。

 關於面向物件的原則

面向物件有著七大基本原則,分別是開閉原則,單一職責原則,里氏代換原則,迪米特原則,介面隔離原則,依賴倒置原則和合成複用原則。接下來給我出認為最重要的兩個原則,也就是前兩個原則。

開閉原則:

這裡給出的開閉並不是所謂門的開關閉合,而是對擴充套件開放,對修改閉合。對模組的功能進行開放,需要增加功能只需要新增加一個新的類去接上,不需要去修改已經完成的類的程式碼。根據前面的講解可以得知,面向物件的可複用設計的基石,其他設計原則是實現開閉原則的手段和工具。

單一職責原則:

單一職責的職責可以就簡單理解為行為,類是一個物體,物體的行為分為不同的職責,將不同的職責分開裝入不同的類之中,負責所單一的職責來實現單一職責原則。這樣做的好處有:類的複雜度降低,可讀性提高,可維護性提高,擴充套件性提高,降低變更引起的風險。

這兩種原則在接下來的PTA大作業中給出的類圖中都有針對性的進行設計。

PTA中遇到的bug和問題

此處就類舉一下寫作業中碰到的問題與bug

PTA6-8(電信計費):

1.精度問題。

2.計費方式錯誤計算導致的錯誤。

3.類的錯誤或遺漏設計導致的錯誤。

4.對電話號碼進行matches錯誤設計導致的錯誤。

總結: bug來源主要來自以下四點: 1.對計費方式理解的欠缺,一開始沒有理解到一分鐘多1s也算作2分鐘。 2.考慮不周到,很多情況沒有考慮到。 3.自己對題目的觀察理解不夠透徹,導致健壯性的不完善。 4.不小心寫錯。  

 程式碼分析

(程式碼量太大這裡不給出全程式碼,部分題目給出關鍵的程式碼,只給出類圖和耦合度以及對題目的分析)

PTA6
  7-1  電信計費系列1-座機計費
  類圖: 耦合度:

程式碼:

在給出類圖的類後,新增加了判斷類,來對輸入資料進行判斷以及接收。

class InputDeal {
    
    public int checkInput(String s)
    {
        int returnNum = 0;
        String[] input = s.split(" ");
        //輸入u-xxxx的情況
        if(input.length == 2) {
            if (input[0].matches("^u-[0-9]{11,13}$")) {
                Integer r = Integer.parseInt(input[1]);
                if(r>=0 && r<=2)
                    returnNum = 1;                                
            }
        }
        //輸入t-xxxx的情況
        else if(input.length == 6) {
            if(judgeMent_t(input))
                returnNum = 2;
        }
        return returnNum;
    }
    public boolean judgeMent_t(String[] input) {
        if (valiDateDate(input[2]))
            if (valiDateDate(input[4]))
                if (valiDateTime(input[3]))
                    if (valiDateTime(input[5]))
                        if (input[0].matches("[t]-0791[0-9]{7,8}"))
                            if (input[1].matches(".[0-9]{9,11}")) {
                                return true;    
                            }
        return false;                
    }
    public boolean valiDateTime(String s) {
        if( s.matches("^([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$") ) {
            return true;
        }
            return false;
    }
    public boolean valiDateDate(String s) {
        if(!s.matches("\\d{4}+[\\.]\\d{1,2}+[\\.]\\d{1,2}"))
            return false;
        String[] ss = s.split("\\.");
        //分出年月日
        int year = Integer.parseInt(ss[0]);
        int month = Integer.parseInt(ss[1]);
        int day = Integer.parseInt(ss[2]);
        
        if(month<1 && month>12)
            return false;
        int[] monthArray = new int[]{0,31,28,31,30,31,30,31,31,30,31,30,31};
        
        if( isRunNian(year) )
            monthArray[3] = 29;
        
        int monthLength = monthArray[month];
        if (day < 1 || day > monthLength) {
            return false;
        }
        return true;
    }
    /**
     * @判斷是否是閏年(是返回true,否返回false)
     */
    public boolean isRunNian(int year) {
        return ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0);
    }
    /**
     * @輸入使用者資訊
     */
    public void InputUser(ArrayList<User> users,String s) {
        //u-079186300001 0
        User newUser = new User();
        String[] input = s.split(" ");
        newUser.setNumber( input[0].substring(2) );
        //檢查是否有號碼相同,相同則結束本次輸入
        for( User user : users) {
            if( user.getNumber().equals(newUser.getNumber()) )
                return;
        }
        int mode = Integer.parseInt( input[1] );
        //選擇計費型別
        switch (mode) {
            case 0 :  newUser.setChargeMode( new LandlinePhoneCharging() );break;
            default :
        }
        
        users.add(newUser);
    }
    /**
     * @輸入使用者的通訊資訊
     */
    public void InputRecord(ArrayList<User> users,String s) {
        //t-079186330022 058686330022 2022.1.3 10:00:25 2022.1.3 10:05:11
        String[] input = s.split(" ");
        String callingNumber = input[0].substring(2);
        String answerNumber = input[1];
//        if(!callingNumber.matches("[079[0-9]|0701]+[0-9]{7,8}"))
//            return;
        CallRecord callRecord = new CallRecord(input);
        
        User calus = null;
        User ansus = null;
        //選擇正確的使用者
        for( User us : users ) {
            if( us.getNumber().equals(callingNumber) )
                calus = us;
            if( us.getNumber().equals(answerNumber) )
                ansus = us;
            if(calus!=null && ansus!=null)
                break;
        }
        //打電話使用者記錄
        if (calus != null) {
            if (callRecord.getCallType() == 1)
                calus.getUserRecords().addCallingInCityRecords(callRecord);
            else if (callRecord.getCallType() == 2)
                calus.getUserRecords().addCallingInProvinceRecords(callRecord);
            else
                calus.getUserRecords().addCallingInLandRecords(callRecord);
        }
        //接聽使用者記錄
        if (ansus != null) {
            if (callRecord.getCallType() == 1)
                ansus.getUserRecords().addAnswerInCityRecords(callRecord);
            else if (callRecord.getCallType() == 2)
                ansus.getUserRecords().addAnswerInProvinceRecords(callRecord);
            else
                ansus.getUserRecords().addAnswerInLandRecords(callRecord);
        }
    }

}

PTA7
  7-1 電信計費系列2-手機+座機計費
  類圖:

耦合度:

程式碼:

對輸入類檢測輸入的修改

public int checkInput(String s)
    {
        if (s.matches("[u]-0791[0-9]{7,8}\\s[0]") || s.matches("[u]-1[0-9]{10}\\s[1]")) {
            return 1;
        } else if (s.matches("(([t]-0791[0-9]{7,8}\\s" + "0[0-9]{9,11}\\s)|"
                + "([t]-0791[0-9]{7,8}\\s" + "1[0-9]{10}\\s" + "0[0-9]{2,3}\\s)|"
                + "([t]-1[0-9]{10}\\s" + "0[0-9]{2,3}\\s" + "0[0-9]{9,11}\\s)|"
                + "([t]-1[0-9]{10}\\s" + "0[0-9]{2,3}\\s" + "1[0-9]{10}\\s" + "0[0-9]{2,3}\\s))"
                
                + "((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]|[0-9][1-9][0-9]{2}|[1-9][0-9]{3})\\.(((0?[13578]|1[02])\\.(0?"
                + "[1-9]|[12][0-9]|3[01]))|(([469]|11)\\.([1-9]|[12][0-9]|30))|(2\\.([1-9]|[1][0-9]|2[0-8]))))|((("
                + "[0-9]{2})([48]|[2468][048]|[13579][26])|(([48]|[2468][048]|[3579][26])00))\\.2\\.29))"
                + "\\s([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])\\s"
                + "((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]|[0-9][1-9][0-9]{2}|[1-9][0-9]{3})\\.((([13578]|1[02])\\.("
                + "[1-9]|[12][0-9]|3[01]))|(([469]|11)\\.([1-9]|[12][0-9]|30))|(2\\.([1-9]|[1][0-9]|2[0-8]))))|((("
                + "[0-9]{2})([48]|[2468][048]|[13579][26])|(([48]|[2468][048]|[3579][26])00))\\.2\\.29))"
                + "\\s([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])")) {
            return 2;
        }
        return 0;
    }

這裡由於需要考慮的情況有些多,所以直接照搬了網上的程式碼。

直接在CallRecord中加入的判斷語句

/**
 * @通話記錄類
 * @父類:通訊記錄抽象類CommunicationRecord
 */
class CallRecord extends CommunicationRecord {
    private Date startTime; //通話的起始時間
    private Date endTime; //通話的結束時間
    private String callingAddressAreaCode; //撥號地點的區號
    private String answerAddressAreaCode; //接聽地點的區號
    public CallRecord() {
        
    }
    public CallRecord(String[] input) {
        super();
        char type = input[0].charAt(0);
        input[0] = input[0].substring(2);
        String d1=null,t1=null,d2=null,t2=null;
        if(type == 't')
        switch ( input.length ) {
            case 6: d1=input[2];t1=input[3];d2=input[4];t2=input[5];
                    callingAddressAreaCode = input[0].substring(0,4);
                    answerAddressAreaCode = input[1].substring(0,4);
                    break;
            case 7:    d1=input[3];t1=input[4];d2=input[5];t2=input[6];
                if(input[0].charAt(0) != '0') {
                    if(input[2].length() == 10) {
                        answerAddressAreaCode = input[2].substring(0,3);
                    } else {
                        answerAddressAreaCode = input[2].substring(0,4);
                    }
                    callingAddressAreaCode = input[1];
                }
                else {
                    if(input[0].length() == 10) {
                        callingAddressAreaCode = input[0].substring(0,3);
                    } else {
                        callingAddressAreaCode = input[0].substring(0,4);
                    }
                    answerAddressAreaCode = input[2];
                }
                break;
            case 8:    d1=input[4];t1=input[5];d2=input[6];t2=input[7];
                    callingAddressAreaCode = input[1];
                    answerAddressAreaCode = input[3];
                    break;
            default : break;
        }
        else if(type=='m'){
            
        }
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy.MM.dd HH:mm:ss", Locale.getDefault());
        try {
            startTime = simpleDateFormat.parse(d1 + " " + t1);
            endTime = simpleDateFormat.parse(d2 + " " + t2);
        } catch (ParseException e) {
        }
    }
    /**
     * @return String 前面表示撥打電話(1表示市內,2表示省內,3表示省外)後面表示接聽電話(1表示市內,2表示省內,3表示省外)
     */
    public String getCallType() {
//        System.out.println(callingAddressAreaCode+" "+answerAddressAreaCode);
        String s = "";
        if (callingAddressAreaCode.equals("0791")) {
            s = s.concat("1");
        }
        else if (callingAddressAreaCode.matches("^079[023456789]$") || callingAddressAreaCode.equals("0701")) {
            s = s.concat("2");
        }
        else {
            s = s.concat("3");
        }
        
        if (answerAddressAreaCode.equals("0791")) {
            s = s.concat("1");
        }
        else if (answerAddressAreaCode.matches("^079[023456789]$") || answerAddressAreaCode.equals("0701")) {
            s = s.concat("2");
        }
        else {
            s = s.concat("3");
        }
        return s;
    }
    public Date getStartTime() {
        return startTime;
    }
    
    public void setStartTime(Date startTime) {
        this.startTime = startTime;
    }
    
    public Date getEndTime() {
        return endTime;
    }
    
    public void setEndTime(Date endTime) {
        this.endTime = endTime;
    }
    
    public String getCallingAddressAreaCode() {
        return callingAddressAreaCode;
    }
    
    public void setCallingAddressAreaCode(String callingAddressAreaCode) {
        this.callingAddressAreaCode = callingAddressAreaCode;
    }
    
    public String getAnswerAddressAreaCode() {
        return answerAddressAreaCode;
    }
    
    public void setAnswerAddressAreaCode(String answerAddressAreaCode) {
        this.answerAddressAreaCode = answerAddressAreaCode;
    }
    /**
     * @return double型別的通話時長(單位s)
     */
    public double getTalkTime() {
        return (endTime.getTime() - startTime.getTime())/1000;
    }
}

PTA8:

7-1 電信計費系列3-簡訊計費

類圖:

耦合度:

 因為每道題目所需要更改的部分基本都一至,按照要求進行相應的修改即可,並且最後一次很簡單,這邊也不給出程式碼了

對電信計費系列的分析: 這次電信計費系列還是很簡單的,按照給定的類圖進行相應的設計後即可實現大體上的功能,需要注意的地點一共有三點,一個就是輸入的檢測,檢測是User還是被打電話的人,其中的判斷在PTA中佔有的分值也是挺高的。第二點就是在設計計費方式的方面,要注意到多1s多記1分鐘的。最後一點其實是在檢測計費方式的方面,以為t-後的電話型別可能分很多種,也就是要考慮自己的位置和對面的位置所相對應出相應的計費方式,這一點非常重要,其中我也因為考慮不周到踩到了不少的坑。總之這次pta只要將這幾點考慮周到應該是沒什麼太大問題的,將第一次的pta6設計完後,後面幾次只要做相應的修改還是比較簡單的

 總結與感想:

三次大作業雖然難度不大,但也讓我學到了很多。從自己硬寫高複雜度的爛程式碼,到從類圖中提取有效資訊,按照類圖來寫高質量程式碼,並由此更深刻地體會到面向物件的魅力、面向物件程式設計所帶來的簡潔、程式碼修改的方便,java的學習讓我程式設計時的思路更加清晰、明朗。

        期末考試的順利結束,意味著這個學期的java學習正式告一段落。這是本學期的最後一篇java部落格,也是java課的最後一個任務。我在這個學期的java學習過程中,遇到了大大小小的困難,被一次次地搞心態,但是最後還是挺過來了。學習嘛,不遇到幾次困難你永遠不知道自己幾斤幾兩,也永遠不會進步。java課程的結束,並不意味著java學習的結束。技術發展日新月異,我們在短短一學期內所學到的,永遠只是java宇宙的冰山一角。其它的學科也一樣。學習也不能侷限於學校裡學的知識。學習不是一蹴而就的過程,更要的是博識多學、堅持不懈。千淘萬漉雖辛苦,吹盡狂沙始到金。人生也是這樣,克服所遇到的困難,讓自己閃現出金子般的光芒!最後,在此感謝老師同學們對我java學習所提供的幫助!