Select Page

CMPSC 465 Pennsylvania State University Distinct Integers & Problem Description Coding

Question Description

https://github.com/Shao-Group/cmpsc465-fa20/tree/master/assignment2

Problem Description

Given an array A with n distinct integers, design an algorithm to count the number of pairs (A[i],A[j]) satisfying that i < j and A[i] > A[j].

Input

Two lines, the first line gives only one number n, the number of integers in the array. And the second line gives n numbers which are the n integers in the array. All numbers are separated by space.

You can assume that 0 <= n <= 50000, and that each number in the arrarys are in the range of [-2147483648, 2147483647].

Your code should read the input from standard input (e.g. using functions input()/raw_input() in Python and cin/scanf in C++).

Output

One number in a line, representing the number of pairs (A[i],A[j]) satisfying that i < j and A[i] > A[j].

Your code should write the output to standard output (e.g. using functions print in Python and cout/printf in C++).

Requirement

Your algorithm should run in O(nlogn) time. You are not allowed to call any in-built sort function.

Time limtation: 5 seconds.

Memory limitation: 1.0 GB.

Environment

Your code will be running on Ubuntu 18.04.5.

Now only accept C++ and Python2/Python3 code, g++ version 7.5.0 and Python versions are Python 2.7.17 and Python 3.6.9.

Examples and Testing

Some examples (e.g., input-x.txt and output-x.txt, x = 1, 2) are provided. For Python code, try the following to test your code

python ./solution.py < input-x.txt > my-output-x.txt

For C++ code, try the following to test your code

g++ -o mybinary solution.cpp./mybinary < input-x.txt > my-output-x.txt

Your output my-output-x.txt needs to be match exactly to the given output-x.txt. On Unix-based systems you can use diff to compare them:

diff my-output-x.txt output-x.txt

On Windows you can use fc to compare them:

fc my-output-x.txt output-x.txt

Submission

If you want to upload a single file, make sure the file is named as solution.py (for Python) or solution.cpp (for C++). If you submit via GitHub, make sure your file is located in directory assignment2/problem1/solution.py (for Python) or assignment2/problem1/solution.cpp (for C++).

Related Material

Refer to Chapter 5.3, Algorithm Design [KT].

Hints

Reuse the code you write for assignment 1

Problem Description

Given a set of lines, each line is represented as y = a * x + b. Calculate the number of lines in the upper-envelop and the number lines in the lower-envelop. (You may assume that there is no three lines going through the same point. And for any three lines, they can’t be in all parallel to each other, but it’s possible that two lines are parallel to each other.)

Input

There are n + 1 lines, the first line gives only one number n, the number of lines. Each of the following lines contains two floating numbers a and b separated by space which represent a line as y = a * x + b.

You can assume that 0 <= n <= 1000, and that each floating numbers are in the range of [-100.0, 100.0].

Your code should read the input from standard input (e.g. using functions input()/raw_input() in Python and cin/scanf in C++).

Output

Two numbers in a line separated by space, the number of lines in the upper-envelop and the number lines in the lower-envelop.

Your code should write the output to standard output (e.g. using functions print in Python and cout/printf in C++).

Requirement

Your algorithm should run in O(nlogn) time.

Time limtation: 5 seconds.

Memory limitation: 1.0 GB.

Environment

Your code will be running on Ubuntu 18.04.5.

Now only accept C++ and Python2/Python3 code, g++ version 7.5.0 and Python versions are Python 2.7.17 and Python 3.6.9.

Examples and Testing

Some examples (e.g., input-x.txt and output-x.txt, x = 1, 2) are provided. A figure corresponding input-1 can be found in this repo too. For Python code, try the following to test your code

python ./solution.py < input-x.txt > my-output-x.txt

For C++ code, try the following to test your code

g++ -o mybinary solution.cpp./mybinary < input-x.txt > my-output-x.txt

Your output my-output-x.txt needs to be match exactly to the given output-x.txt. On Unix-based systems you can use diff to compare them:

diff my-output-x.txt output-x.txt

On Windows you can use fc to compare them:

fc my-output-x.txt output-x.txt

Submission

If you want to upload a single file, make sure the file is named as solution.py (for Python) or solution.cpp (for C++). If you submit via GitHub, make sure your file is located in directory assignment2/problem2/solution.py (for Python) or assignment2/problem2/solution.cpp (for C++)..

"Place your order now for a similar assignment and have exceptional work written by our team of experts, guaranteeing you "A" results."

Order Solution Now