联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> C/C++编程C/C++编程

日期:2022-04-27 09:21

Documentation

For this assignment (and all assignments in this unit) you are required to document and comment

your code appropriately. This documentation/commenting must consist of (but is not

limited to):

• For each function, high-level description of that function. This should be a two or three

sentence explanation of what this function does and the approach undertaken within the

function.

• For each function, specify what the input to the function is, and what output the function

produces or returns (if appropriate).

• For each function, the Big-O time and space complexity of that function, in terms of the

input size. Make sure you specify what the variables involved in your complexity refer

to. Remember that the complexity of a function includes the complexity of any function

calls it makes.

• Within functions, comments where appropriate. Generally speaking, you would comment

complicated lines of code (which you should try to minimise) or a large block of code

which performs a clear and distinct task (often blocks like this are good candidates to be

their own functions!).

A suggested function documentation layout would be as follows:

def my_function(argv1, argv2):

"""

High level description about the functiona and the approach you

have undertaken.

:Input:

argv1:

argv2:

:Output, return or postcondition:

:Time complexity:

:Aux space complexity:

"""

# Write your codes here.

4

1 Salesperson Revenue

(4 marks + 1 mark for documentation)

You are a travelling salesperson that sells your products in n cities (numbered 0, 1,...,n

1)

and you are trying to decide your schedule for the next d days (numbered 0, 1,...,d

1) in

order to maximize your revenue. You need to decide when it is better to sell on the city you

are located in and when it is better to move to another city.

As a super-competent salesperson, you already know how much revenue you would be able to

make on each day in each city. revenue is a list of lists. All interior lists are length n. Each

interior list represents a different day. revenue[z][x] is the revenue that you would make if

you work in city x on day z.

You also have information about travel routes. travel_days is a list of lists. travel_days[x][y]

will contain either:

• A positive integer number indicating the number of days you need to spend to travel on

the direct road from city x to city y.

• -1, to indicate that there is no direct road for you to travel from city x to city y.

At the beginning of each day z, if you are located in some city x, you have the following options:

• Spend the whole day selling in that city, making a revenue of revenue[z][x] on day z.

• Start a travel on the direct road to some city y. In this case this travel will start in city x at

the beginning of day z and will finish in city y at the end of day z+travel_days[x][y]1

(and you will not be able to do anything other than travel on the road from city x to city

y on days z,..., z + travel_days[x][y]

1).

Let start denote the city you start in on day 0.

To solve this problem, you should write a function best_revenue(revenue, travel_days,

start) that returns the maximum possible revenue.

1.1 Complexity

Your solution should have a worst-case time complexity of O (n2 (d + n)).

5

2 Saving the Multiverse

(4 marks + 1 mark for documentation)

You are Dr Weird, gifted with the power travel across the multiverse. Your archnemesis Master

X has duplicated himself and sends copies of himself across the multiverse.

Through the power of the echo, you are able to see when Master X would attack each multiverse:

• Multiverse 1, from day 2 to day 7 with a force of 5 clones.

• Multiverse 2, from day 1 to day 4 with a force of 4 clones.

• Multiverse 3, from day 6 to day 9 with a force of 2 clones.

• ... and so on.

Through masterful planning, Master X is able to coordinate his attacks and you can only be

at a single multiverse at a single moment of time. Thus, you would need to decide which

multiverse to be at to stop him; leaving the rest to each multiverse’s defenders. In the example

above, you can either:

• Defend multiverse 1 from day 2 to day 7; defeating 5 clones; or

• Defend multiverse 2 from day 1 to day 4 and then head to multiverse 3 from day 6 to day

9. In total, you would have defeated 6 clones.

Your goal is to defeat the most Master X clones you can in order to weaken him. In order to

do so, you wrote a simple Python function hero(attacks) to quickly determine the optimal

multiverse travel before Master X rules the multiverse.

PS: You can assume that you will always defeat the Master X clones. As a hero, you would

always find a way and wouldn’t need any hints.

2.1 Input

attacks is a non-empty list of N attacks, where each attack is a list of 4 items [m, s, e, c]:

• m is the multiverse which Master X is attacking.

– m is an integer in the range of 1 to N.

– Master X will only attack each multiverse once; because he do not like setbacks.

• s and e are the starting and ending days of the attack.

– s and e are integers in the range of 1 to D.

– You can assume that s <= e.

– You would need to be throughout the entire attack duration from day s to day e

inclusive in order to defeat the clones.

• c is the number of Master X clones in the attack.

– c is an integer in the range of 2 to C.

– Master X will always attack with at least 2 clones because he needs friends.

6

2.2 Output

Your algorithm returns a list of Master X attacks that you, Dr Weird, will attend to:

• Result in the most Master X clones defeated.

• The returned list doesn’t need to be sorted.

• It is possible for the return list to not be unique.

2.3 Examples

Consider the following examples below.

The first example is based on the simple example given in the question description where a

total of 6 clones were defeated.

# Example 01

attacks = [[1, 2, 7, 5], [2, 1, 4, 4], [3, 6, 9, 2]]

>>>hero(attacks)

[[3, 6, 9, 2], [2, 1, 4, 4]]

For the second example below, we observe 2 possible solutions where either [[3, 5, 6, 2], [2, 1, 4, 4]]

or [[1, 2, 7, 6]] would result in 6 clones being defeated.

# Example 02 (not unique)

attacks = [[1, 2, 7, 6], [2, 1, 4, 4], [3, 5, 6, 2]]

>>>hero(attacks)

[[3, 5, 6, 2], [2, 1, 4, 4]]

In the last example below, it can be observed that upon defeating the clones in the attack

[1, 2, 7, 6] you can only move on to attack [3, 8, 9, 5] because attack [2, 7, 9, 10] starts on day 7

itself when you are still occupied.

# Example 03 (ending condition overlap)

attacks = [[1, 2, 7, 6], [2, 7, 9, 10], [3, 8, 9, 5]]

>>>hero(attacks)

[[3, 8, 9, 5], [1, 2, 7, 6]]

2.4 Complexity

hero(attacks) should run in O(NlogN) worst case time complexity and O(N) auxiliary space

complexity, given that N is the number of attacks in attacks.

7

Warning

For all assignments in this unit, you may not use python dictionaries or sets. This is because

the complexity requirements for the assignment are all deterministic worst-case requirements,

and dictionaries/sets are based on hash tables, for which it is difficult to determine the deterministic

worst-case behaviour.

Please ensure that you carefully check the complexity of each in-built python function and

data structure that you use, as many of them make the complexities of your algorithms worse.

Common examples which cause students to lose marks are list slicing, inserting or deleting

elements in the middle or front of a list (linear time), using the in keyword to check for

membership of an iterable (linear time), or building a string using repeated concatenation

of characters. Note that use of these functions/techniques is not forbidden, however you

should exercise care when using them.

These are just a few examples, so be careful. Remember, you are responsible for the complexity

of every line of code you write!

8


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp