UIT2201: CS & the IT Revolution
Review Topics for Mid-Term (Fall 2016)
Here are some general information on the Mid-Term (for your reference).
Mid-Term, the Questions:
-
Date:
Wednesday, 05-Oct-2016; 7-8pm; Venue: TBA
- Mid-Term is CLOSED BOOK / CLOSED NOTES.
- It is 1 hour --- and starts at 7pm SHARP.
- Mid-Term will consist of short questions (about 4 of them).
- ANSWER ALL QUESTIONS -- in the question book itself.
The questions will be similar to those in the
tutorials and the notes. But, usually shorter.
(There will be a fun bonus-mark question.)
Topics Covered:
- Topics 1-4 (excluding "Basic database primitves and Concurrency");
- Everything covered until Week 7 (T1-T7, last tut class - 30 Sep)
- Textbook [SG3] Chapters 1-3; Ch 13.3 (excluding 3.4.1, pp.99-105)
- Lectures (including handouts given out in class),
- Tutorials (all problems except A-problems),
Some Review Questions (RQ):
Some sample question for your reference. Of course, there is
no guarantee that all the Quiz questions are like that.
This is for reference only!
RQ-0
Review all the tutorial problems given to you.
RQ-1. [True/False]
For each of the following, answer TRUE or FALSE.
- A repeat-until loop can execute 0 times. _________
- One fundamental virtue of an algorithm is that if we can specify an
algorithm for solving a problem, then we can implement the algorithm
and have a very fast (and so practical) solution of the problem
since computers are very fast computing machines. _________
- Whether or not an operation is a primitive depends,
in part, on the computing agent that is
expected to execute it. _________
- Computer science work was done before the electronic computer was invented.
_________
- It is theoretically possible to build a decimal computer -- that is, a computer
that uses decimal numbers internally.
_________
- If different people construct a truth table from the same circult diagram,
they will always get the identical truth table (as long as it is correctly done).
_________
- A tuple consists of a row of attributes. _________
- There should not be more than one table (relation) in a database. _________
- Can include something on Scratch or Simple Scratch programs / blocks.
RQ-2. (Short Answers)
- Give the definition of computer science as given in the
textbook [SG3].
- Determine if the following are unambiguous, effectively computable operations.
Explain your reasoning for those that are not effectively computable.
- Read in the value of n;
- Check if X equals Y.
- List the positive, odd integers greater than 2201.
- How do we define a database?
RQ-3.
At the beginning of the course, we have seen several
very diverse computing devices that come from different domains.
These includes email, ATM machine, course enrolment, online library
search, MP3 music access, 3-D walkthrough.
- What are some of the common capabilities of all these
diverse and different computing devices.
- Compare and contrast them with respect to these common capabilities.
RQ-4.
Modify the algorithm of Figure 2.10 (the "Find Largest Algorithm)
so that it computes the number of occurrences of the value x in
a list of n numbers.
RQ-5. (Not applicable for Fall 2016)
Explain how the popular outdoor game of scavenger hunt
can be defined recursively. Remember to also include the base case.
RQ-6.
Describe the best case input of the sequential search algorithm.
How many comparisons are required in a search of n items in this case?
RQ-7.
Describe the worst case input for an unsuccessful search using
the sequential search algorithm.
How many comparisons are required in a search of n items in this case?
RQ-8.
For what input sizes n is an algorithm (A) that does 50n
units of work slower than an algorithm that does 2n2
units of work.
RQ-9.
Give an example of a linear time algorithm, namely, an algorithm
that has time complexity O(n), where n is the input size.
RQ-DB1.
Consider the database schema given in Lectures.
Given the following sequence of SQL statements:
T1 <-- SELECT from ENROLMENT where (COURSE-ID="NN")
T2 <-- JOIN T1 and STUDENT-INFO
where (STUDENT-INFO.Student-ID = T1.Student-ID)
T3 <-- SELECT from T2 where (Faculty="FASS")
A <-- PROJECT T3.Name from T3;
Suggest ways to modify the query to make it computationally more efficient.
UIT2201: CS & IT Revolution; (Fall 2016); A/P Leong HW