合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

        COMP1117B代做、代寫Python編程設計

        時間:2024-05-02  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



        COMP1117B Computer Programming
        Assignment 4
        Due date: Apr 29, 2024, 23:59
        Reminder
        This assignment involves a lot of console input/output. You are reminded that the VPL
        system on HKU Moodle evaluates your program with a full score under the condition that
        your program output is the EXACT MATCH of the expected output. In other words, any
        additional or missing space character, newline character, etc., will be treated as errors
        during the evaluation of your program. Also, you are suggested to design more test cases on
        your own for testing your program.
        You are allowed to use any Python built-in functions. However, you cannot import modules other
        than those mentioned in this assignment.
        Objective
        Your client, XYZ Company, provides car rental services. For this assignment, you are to develop
        a rental system for the company’s internal management of rental transactions. The system should
        allow managers to analyze rental data and query whether a specific car is available for a new
        rental.
        The techniques we learned in the previous chapters, such as Files, Sets, Dictionaries, and Tuples,
        would be useful for handling this assignment.
        Import Data from File
        The company’s rental transaction data is stored in a text (.txt) file. Each row represents a rental
        transaction with the following fields separated by a single space:
        • Car ID (e.g., 01)
        • Rental Start Date (e.g., 2024-04-15)
        • Customer ID (e.g., 001)
        • Rental Fee per Day (integer)
        • Rental Days (e.g., 5)
        For example, a text file (data.txt) with five records has the following content:
        01 2024-04-15 001 50 1
        08 2024-04-25 002 45 6
        01 2024-05-05 001 50 10
        01 2024-05-20 003 60 30
        15 2024-05-20 002 45 8
        2 IN 9
        The program should be able to read the file by specifying the name of the data file.
        Below is the input and output for loading the file data when the program starts (Text in
        bold is user input):
        Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        Notes:
        • The program should automatically assign transaction IDs for each line of the transaction
        data (the data.txt file). The transaction ID starts with 1 and then increases by 1 for each
        row of the records. For example, the assigned ID of the first line of the transaction data
        (01 2024-04-15 001 50 1) is 1, then the next line transaction’s ID is 2, and so on
        and so forth.
        • The program has not been terminated yet.
        Hints:
        • You might use a dictionary to store the transaction records after reading the .txt file.
        • You might use split() to split a string into a list.
        Main Menu
        After importing course sessions from the file, the system enters the main menu and
        reads a user command repeatedly until the user inputs “Exit”. You should implement the
        following SIX commands for the system.
        The example data.txt file mentioned in the previous section is used for the following cases.
        1. Exit
        By inputting the command Exit, the program prints "Thank you for using the Car Rental
        System. Goodbye!" and terminates.
        Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        Exit
        Thank you for using the Car Rental System. Goodbye!
        3 IN 9
        2. CarTransaction
        By inputting the command CarTransaction, the system lists all cars in the rental
        transaction records based on the imported data. Prints the car ID and the number of rental
        transactions for each car. Sorts the records in ascending order by the Car ID.
        Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        CarTransaction
        Here is the rental transaction for the cars:
        The Car 01 has been rented 3 time(s).
        The Car 08 has been rented 1 time(s).
        The Car 15 has been rented 1 time(s).
        3. CarHistory | <car_ID>
        This command can list the transaction summary of the specific Car ID in the format
        shown in the example below. The records should be sorted by the total number of
        rental days in descending order. You can assume that no records have the same total
        number of rental days.
        Total number of rental days is the sum of the rental days made by the <customer_ID> on
        <car_ID>.
        The records by the same customer should be merged. For example, assuming Customer
        001 made two transactions on Car 01 with rental days of 1 and 10 days, respectively, the
        total number of rental days for Customer 001 on Car 01 should be 11.
        Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        CarHistory | 01
        Here is the rental summary for the Car 01:
        Customer 003 30 day(s)
        Customer 001 11 day(s)
        4. RentalPeriodAnalysis | <start_date> | <end_date>
        This command lists all rental transactions’ starting date time within a specific period
        (includes the inputted start and end dates). Display the following information for that period
        (sort the records in ascending order by the transaction ID):
        4 IN 9
        Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        RentalPeriodAnalysis | 2024-04-15 | 2024-04-25
        Rental summary record(s) from April 15, 2024 to April 25, 2024:
        01 2024-04-15 001 50 1
        08 2024-04-25 002 45 6
        5. TopSpendCustomers | <number>
        This command determines the top customers based on their total spend amount across all
        rental transactions. The <number> parameter specifies the maximum number of top
        customers to display.
        Display the customer ID, total spend amount, and the number of
        transactions for each top customer. Sort the records in descending order by total
        spend amount. You can assume that no records have the same total spend
        amount in the data.
        Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        TopSpendCustomers | 2
        Here are the top 2 customer(s) by total spend amount:
        Customer 003 has spent $1800 on 1 transaction(s).
        Customer 002 has spent $630 on 2 transaction(s).
        6. CheckCarAvailability | <car_id> | <rental_start_date> | <days_of_rental>
        This command allows the manager to check if a specific car is available or occupied during
        a given rental period. If the car was occupied for any part of the date range, even just a
        single day, then the entire period is considered occupied. The <car_id> parameter
        represents the car's ID to check. The <rental_start_date> parameter represents the
        rental start date to check for availability. The <days_of_rental> parameter represents
        the number of days lasting for rental.
        If the car is not found in the rental transaction records, display the message “The car is not
        found.” indicating that the car is not in the previous transaction records.
        If the car is found, check whether it is available or occupied based on the rental transaction
        records and the attempted rental period.
        5 IN 9
        Print the message “The Car <ID> is available in this period.” indicates the car is available.
        If the car is occupied, print the message “The Car <ID> is occupied in this period.” Then,
        print all the occupied days by line (see the example below).
        Example 1 Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        CheckCarAvailability | 01 | 2024-04-20 | 1
        The Car 01 is available in this period.
        Example 2 Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        CheckCarAvailability | 01 | 2024-05-08 | 6
        The Car 01 is occupied in this period.
        The occupied date(s):
        2024-05-08
        2024-05-09
        2024-05-10
        2024-05-11
        2024-05-12
        2024-05-13
        Example 3 Transaction records to import:
        data.txt
        Imported 5 transaction(s) to the system.
        CheckCarAvailability | 20 | 2024-05-10 | 1
        The car is not found.
        Tips:
        • The datetime module in Python contains useful functions for handling dates and times.
        To use these functions, you need to import the datetime module at the beginning of
        your code.
        Example: from datetime import datetime, timedelta
        • Parsing Dates:
        You can use the datetime.strptime() function to parse a string representation of a date into
        a datetime value.
        Example: date = datetime.strptime("2024-04-15", "%Y-%m-%d")
        6 IN 9
        • The previous tip, “parsing dates,” is the prerequisite for the functionality of the tips below
        on “comparing dates,” “formatting dates,” and “date arithmetic.”
        • Comparing Dates:
        You can directly compare datetime values using comparison operators
        like <, <=, >, >=, ==, and !=.
        Example: if start_date <= date <= end_date:
        • Formatting Dates:
        You can use the strftime() method of a datetime value to format it as a string.
        Example:
        date = datetime.strptime("2024-04-15", "%Y-%m-%d")
        formatted_date = date.strftime("%B %d, %Y") will format the date as
        "April 15, 2024".
        • Date Arithmetic:
        You can perform date arithmetic using the timedelta class from
        the datetime module.
        Example: new_date = date + timedelta(days=5) will add 5 days to the
        variable date.
        • We provide the program structure for this assignment on the next page. You can include
        these functions in your program and start working from them, or you can also choose to
        design your program all from scratch.
        7 IN 9
        8 IN 9
        Implementation Notes
        1. You can assume that user inputs and the input file are always valid. That means you
        don’t need to consider cases that have not been mentioned in the requirement.
        2. Do not print space character at the end of output lines.
        3. The input file is used to import data only. Do not modify the input file.
        4. You are allowed to use any Python built-in functions. However, you cannot import modules other
        than those mentioned in this assignment.
        Submission
        Submit your program electronically using the Moodle system to Assignment 4 under the
        Assignment section. Late submissions will not be accepted.
        • Your program must follow the format of the sample input and output strictly.
        • The sample input file (data.txt) is included in the evaluation environment for test cases
        evaluation. You do not need to upload them.
        • You should only submit source code (*.py)
        • We will grade your program with another set of input files and test cases (Not limited
        to the sample input file data.txt and test cases). That means we will change the input
        file and test cases on Moodle after the submission deadline.
        Policy on Plagiarism according to the General Office of CS Department
        Plagiarism is a very serious academic offence. Students should understand what constitutes
        plagiarism, the consequences of committing an offence of plagiarism, and how to avoid it.
        As defined in the University's Regulations Governing Conduct at Examinations, plagiarism is
        "the unacknowledged use, as one's own, of work of another person, whether or not such
        work has been published.", or put it simply, plagiarism is copying (including paraphrasing)
        the work of another person (including an idea or argument) without proper
        acknowledgement.
        In case of queries on plagiarism, students are strongly advised to refer to "What is
        Plagiarism?" at https://tl.hku.hk/plagiarism/
        If a student commits plagiarism, with evidence after investigation, no matter whether the
        student concerned admits or not, a penalty will be imposed:
        First Attempt: if the student commits plagiarism (in an assignment/test of a CS course) for
        the first time in his/her entire course of study, the student shall be warned in writing and
        receive zero mark for the whole assignment or the whole test; if the student does not agree,
        s/he can appeal to the BEng(CompSc) Programme Director within a week;
        9 IN 9
        Subsequent Attempt: if the student commits plagiarism more than once in higher course of
        study, the case shall be referred to the Programme Director for consideration. The
        Programme Director shall investigate the case and consider referring it to the University
        Disciplinary Committee, which may impose any of the following penalties: a published
        reprimand, suspension of study for a period of time, fine, or expulsion from the University.
        Both the student who copies other's work and the student who offers his/her work for
        copying shall be penalized.
        Teachers should report plagiarism cases to the General Office for records and the issuing of
        warning letters.

        請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp
















         

        掃一掃在手機打開當前頁
      1. 上一篇:代寫EECS 113、Python/Java程序代做
      2. 下一篇:CS 412代做、代寫Python設計程序
      3. 無相關信息
        合肥生活資訊

        合肥圖文信息
        挖掘機濾芯提升發動機性能
        挖掘機濾芯提升發動機性能
        戴納斯帝壁掛爐全國售后服務電話24小時官網400(全國服務熱線)
        戴納斯帝壁掛爐全國售后服務電話24小時官網
        菲斯曼壁掛爐全國統一400售后維修服務電話24小時服務熱線
        菲斯曼壁掛爐全國統一400售后維修服務電話2
        美的熱水器售后服務技術咨詢電話全國24小時客服熱線
        美的熱水器售后服務技術咨詢電話全國24小時
        海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
        海信羅馬假日洗衣機亮相AWE 復古美學與現代
        合肥機場巴士4號線
        合肥機場巴士4號線
        合肥機場巴士3號線
        合肥機場巴士3號線
        合肥機場巴士2號線
        合肥機場巴士2號線
      4. 幣安app官網下載 短信驗證碼

        關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

        Copyright © 2024 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
        ICP備06013414號-3 公安備 42010502001045

        主站蜘蛛池模板: 日韩精品无码久久一区二区三| 无码人妻一区二区三区在线视频| 果冻传媒一区二区天美传媒| 亚洲国产成人一区二区精品区| 婷婷亚洲综合一区二区| AV鲁丝一区鲁丝二区鲁丝三区| 精品视频一区二区三区免费| 国产高清在线精品一区二区| 国产精品亚洲专一区二区三区| 亚洲中文字幕一区精品自拍| 国产成人久久精品区一区二区| 亚洲韩国精品无码一区二区三区| 国产天堂一区二区综合| 国产99精品一区二区三区免费| 国产嫖妓一区二区三区无码| 亚洲日韩一区二区三区| 亚洲精品精华液一区二区| 国产精品一区二区久久| 91国偷自产一区二区三区| 91精品福利一区二区| 偷拍激情视频一区二区三区| 97人妻无码一区二区精品免费 | 射精专区一区二区朝鲜 | 精品女同一区二区三区在线 | 久久精品无码一区二区三区| 中文字幕在线观看一区二区三区| 成人免费av一区二区三区| 中文字幕精品无码一区二区| 国产在线一区二区三区| 亚洲AV日韩AV天堂一区二区三区| 久久国产精品视频一区| 亚洲狠狠狠一区二区三区| 国产日韩一区二区三区| 国产精品一区不卡| 久久久精品日本一区二区三区| 亚洲中文字幕无码一区二区三区| 亚欧成人中文字幕一区 | 精品一区二区三区免费观看| 日本亚洲国产一区二区三区| 精品深夜AV无码一区二区| 亚洲AV香蕉一区区二区三区|