I'm trying to answer clrs intro to alg edition2 exercises. in chapter 27.1-4 there is an exercise which says: "Prove that any sorting network on n inputs has depth at least lg n". so I think that we can use at most (n/2) comparators in each depth and if we assume that we have found a combination of comparators which can sort (n/2) of the numbers in depth1 then we need to sort the other (n/2) of the numbers. So if we keep doing the same thing we're dividing n by two in each depth so the depth of the sorting network would be lgn. Is this conclusion wrong? if it is what is the right way of proving the lower bound of a sorting networks depth.
How to prove that lower bound of a sorting networks depth is lgn?
357 Views Asked by Libnist At
1
There are 1 best solutions below
Related Questions in ALGORITHM
- Two different numbers in an array which their sum equals to a given value
- Given two arrays of positive numbers, re-arrange them to form a resulting array, resulting array contains the elements in the same given sequence
- Time complexity of the algorithm?
- Find a MST in O(V+E) Time in a Graph
- Why k and l for LSH used for approximate nearest neighbours?
- How to count the number of ways of choosing of k equal substrings from a List L(the list of All Substrings)
- Issues with reversing the linkedlist
- Finding first non-repeating number in integer array
- Finding average of an array
- How to check for duplicates with less time in a list over 9000 elements by python
- How to pick a number based on probability?
- Insertion Sort help in javascript -- Khan Academy
- Developing a Checkers (Draughts) engine, how to begin?
- Can Bellman-Ford algorithm be used to find shorthest path on a graph with only positive edges?
- What is the function for the KMP Failure Algorithm?
Related Questions in CLRS
- What is the reason behind calculating GCD in Pollard rho integer factorisation?
- Heapsort algorithm CLRS
- Implementing a randomized quick sort algorithm
- Singly connected directed graphs
- Red Black Tree in C
- Operations on bits when doing binary long division
- Median select algorithm - does it find the absolute median, or a "median of medians" close to the absolute median?
- In Push Relabel algorithms for max flow why is there not path from source s to sink t?
- How to fix an UnboundLocalError caused due to a recursive function call in Python?
- understanding Universal hashing chapter on CLRS
- How to solve a problem on relative asymptotic growth (table) from CLRS?
- Why are not the way parameters/arguments passed considered for the time complexity of an algorithm?
- Does time complexity differ of the implementation of algorithms in different programming languages?
- Do we consider recursive method calls or other method calls inside a method for that method/function's time complexity?
- Average time complexity of open addressing
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
I can think of two.
The first is that you can view a sorting network for n elements as a comparison-based sorting algorithm, and the lower bound on the latter implies that the network does lg n! = n lg n − n + O(log n) comparisons, divided by n/2 comparisons per level is 2 lg n − 1 + O((log n)/n) ≥ lg n if n ≥ 2 (and you can verify n = 1 manually).
The other is that after r rounds, each input can have been shuffled to at most 2r different locations. This can be proved by induction. Each input must be able to reach each output, so 2r ≥ n, which implies r ≥ lg n.
(Better to ask this kind of question on cs.stackexchange.com in the future.)