Exam Flashcards
data:image/s3,"s3://crabby-images/5fe91/5fe91298b1cb14890d009a38db65785ac5fcb347" alt=""
data:image/s3,"s3://crabby-images/d24bd/d24bdd125d9e7b336129357802fcdc06e23eb9ca" alt=""
data:image/s3,"s3://crabby-images/522b8/522b80cdd5d35f3138057db365e2f3bfc7e73e02" alt=""
data:image/s3,"s3://crabby-images/c1e4a/c1e4af6b34a0ff9f32e3a240e84bec8be0a53938" alt=""
- Run the jobs in decreasing order of finishing time f_i
data:image/s3,"s3://crabby-images/80766/807668baaa4a4a5fcd35075ca84b4314ed10fe9f" alt=""
data:image/s3,"s3://crabby-images/2ebe6/2ebe66211197ac57e96a1ea93a6f32e0dcde29d4" alt=""
data:image/s3,"s3://crabby-images/cc6fb/cc6fb0a7875ef575553e621f8464e593f0de926c" alt=""
data:image/s3,"s3://crabby-images/e024f/e024fa591f7e0af21034fd174d12175def1462d8" alt=""
Exchange argument
- Does not decrease optimality
- e.g, in EEF, it still contains an disjoint set of intervals when exchanging the leftmost intervals from set O (optimal set) and A (algorithm set)
data:image/s3,"s3://crabby-images/6156c/6156c9cbe841806e73fbc12deb0e6e3f781ab416" alt=""
data:image/s3,"s3://crabby-images/486ef/486ef72e9ce95237d70fec7849f47fa3f2541fe7" alt=""
data:image/s3,"s3://crabby-images/f12e2/f12e2042b2194294344d979bdd3f4e5f814d33e7" alt=""
data:image/s3,"s3://crabby-images/3eef2/3eef2de562dd4d5900245f7a69d71649a881cb28" alt=""
data:image/s3,"s3://crabby-images/e0201/e02017f7d54137c7c5cb2d6d488a224f843b8e56" alt=""
data:image/s3,"s3://crabby-images/a028c/a028c5767cfb49bdf3380a2ecc6cfa5f937bf49a" alt=""
data:image/s3,"s3://crabby-images/f65fa/f65fa1db1b04276893c1e994637ae67da35eda6b" alt=""
data:image/s3,"s3://crabby-images/ec637/ec63779a1e207ea2533699143208644b6c1d5cf4" alt=""
data:image/s3,"s3://crabby-images/ed8c3/ed8c31c4669183bff13062da0842f1148601f6e7" alt=""
data:image/s3,"s3://crabby-images/60371/60371dfb02c081107519bf75d927a5ea59728fa3" alt=""
data:image/s3,"s3://crabby-images/c9a4d/c9a4d8a57ea55e85a16caf02e28442ccbf851911" alt=""
data:image/s3,"s3://crabby-images/7019f/7019f0162044ebd870c0714bc80141cc4134323f" alt=""
data:image/s3,"s3://crabby-images/38d29/38d296793310264de4b928b61ec67afa14fcfb86" alt=""
data:image/s3,"s3://crabby-images/b73b9/b73b9943c55e7b33b41b3789ff2f7e04d276e307" alt=""
data:image/s3,"s3://crabby-images/046a4/046a4254defbe99a770797dc7933d469928afc45" alt=""
- Show how to swap
- In case of interval scheduling, swap the two leftmost solutions from optimal and algorithms
- Show how the swap doesnt decrease optimality
- In case of interval scheduling, since the interval has EEF, this does not intersect other intervals in the optimal set, hence its also an optimal solution
OPT(j)= max(v_j + OPT(P(j)), OPT(j -1))
we define PU), for an interval j, to be the
largest index i < j such that intervals i and j are disjoint
Definitions
Give definition of Dynamic programming
- Solve problem by solving sub instance of problem
For a given instance of a problem, we consider certain sub-instances
that grow incrementally. For each of these sub-instances it suffices to keep one optimal solution (because, by an exchange argument, no other solution can lead to a better final solution for the entire instance). The optimal values are then computed step by step on the growing sub-instances. A “recursive” formula specifies how to compute the optimal value from the previously computed optimal values for smaller sub-instances. However, it is not applied recursively, rather, the values are stored in an array, and calculations happen in a for-loop.
What are the topics in the course
- Time complexity, O Notation
- Greedy
- Dynamic programming
- Searching, divide and conquer
- Reduction, NP completness
- DAG’s and graph properties
Give stay ahead argument for Interval scheduling
Algorithm has the option to choose candidate j_r as its solution
Types of greedy problem
- Picking out a subset (interval scheduling)
- Then use exchange argument
- Give an ordering
- Use “swapping” argument where you swap the order of the elements
Unroll the following recurrence 2T(n/2) + O(n)
What are some characteristics of algorithms
- Looping
- Looping through the whole input, O(n) complexity
- No looping in algorithm refers to constant time i.e, O(1)
- Elementary operations
- Arithemtic operations
- If conditions - adding/mdulitplication, querying etc… indexing
- Indexing/querying database or array