What is difference between amortized and average complexity? Also what is doubling and incremental strategy while implementing stack using linked list and arrays?
Doubling and incremental strategy while implementing stack using linked list and arrays?
3.6k views Asked by Rahul Kathuria At
1
There are 1 answers
Related Questions in ARRAYS
- How could you print a specific String from an array with the values of an array from a double array on the same line, using iteration to print all?
- What does: "char *argv[]" mean?
- How to populate two dimensional array
- User input sanitization program, which takes a specific amount of arguments and passes the execution to a bash script
- Function is returning undefined but should be returning a matched object from array in JavaScript
- The rules of Conway's Game of Life aren't working in my Javascript version. What am I doing wrong?
- Array related question, cant find the pattern
- Setting the counter (j) for (inner for loop)
- I want to flip an image (with three channels RGB) horizontally just using array slicing. How can I do it with python?
- Numpy array methods are faster than numpy functions?
- How to enter data in mongodb array at specific position such that if there is only 2 data in array and I want to insert at 5, then rest data is null
- How to return array to ArrayPool when it was rented by inner function?
- best way to remove a word from an array in a react app
- Vue display output of two dimensional array
- Undot Array with Wildcards in Laravel
Related Questions in DATA-STRUCTURES
- Why is the runtime for this O(n)?
- Purpose of last 2 while loops in the merge algorithm of merge sort sorting technique
- What is the problem in my "sumAtBis" code?
- Asking code suggestions about data structure and algorithm
- What would be the most efficient way to store multiple sets of fixed arrays (std::vector)?
- About Suffix Trees features
- Getting wrong answer in Binary Search solution
- Are there techniques to mathematically compute the amount of searching in greedy graph searching?
- AVL tree Nth largest operation - How to have all my tests pass? JAVA
- Why does the map size change?
- Complexity in Union of disjointed sets with lists
- Hash collisions in Golang map resolving
- C++ ordered map optimized with index access
- How to sort this list of strings along with the strings and output the result as expected?
- Why deleting an element in a linkedlist costs O(1)
Related Questions in BIG-O
- Why is the runtime for this O(n)?
- What is the average and worst-case time complexity of my string searching algorithm?
- Complexity in Union of disjointed sets with lists
- Usage of merge in linux sort utility
- How to find big o of dependent loops and recursive functions?
- calculating number of operations in algorithm
- How to differentiate between O(n^2) and O(2^n) in dynamic programming with 2 parameters with memoization?
- Having confusion with calculating Big O complexity
- Write code to match a specific Big-O-Notation
- Error vs time complexity in big-O notation
- Time complexity of simultaneous iteration
- Time complexity for recursive binary search that also prints current subarray
- What's the Time Complexity of two separate inner loops nested in an outer loop?
- String manipulation & algorithmic complexity
- Big O notation of string permutation in Python
Related Questions in AVERAGE
- Moving Average of a variable frequency signal
- Finding average of numbers excluding -1
- How to Sum Values by Column 'Date' After Averaging by Column 'Site'?
- Calculate the average of a filtered list/column with a condition (libre office calc)
- Excel - Aggregating Data in One Column Based on Values in Another Column
- DAX, Calculating Average of a measure within a hierarchy
- I have an array of percentages I want to find the average to
- Can't use double, can't use int, what do I use to stop the rounding? (Java)
- How to calculate an average value based on K-nearest neighbors?
- The average results are calculated differently by the same average measure in the DAX for different time periods
- Averaging Multiple Ranges to ignore 0's and N/As
- Split budget column by total number of months to give average monthly budget
- Pairwise differences between rolling average values for different window widths
- Averaging between several arrays javascript
- How to calculate a daily sales average based off the working days in a month
Related Questions in AMORTIZED-ANALYSIS
- Proof Hotlist amortized analysis is O(sqrt(n)) for Insert and Contain Operations - Hotlist Data Structure
- Resizing an array by a non-constant, over and over
- Why does total amortized cost need to be an upper bound on total actual cost?
- Why isn't Python itertools.combinations() in O(1) amortized time complexity?
- Explaining amortized analysis on dynamic array
- Proving that amortized time of insertion and deletion on an expanding array is O(1)
- An example to show that amortized analysis and average-case analysis may give asymptotically different results
- Amortized time complexity: DecreaseKey() in Fibonacci Heap
- Is there a function for condensing an expression that has many redundant terms so as to not have to recalculate them?
- Worst-case time complexity of an algorithm with 2+ steps
- How to amortise revenue / cost by month in SQL (ideally PostgreSQL)
- Is amortized time complexity analysis broken for immutable colections?
- Why is amortized cost of Python list append is O(1) even though it does not double the capacity when there is no space left?
- What time complexity does this graph represent?
- Amortized Cost in Data Structure
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?
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)
Typically, average-case complexity and amortized complexity refer to different concepts. Average-case complexity is usually used when describing the runtime of a randomized algorithm or data structure in the average case. For example, we can talk about the average-case runtime of randomized quicksort (where the pivot is chosen randomly), or the average-case runtime of a skiplist.
Amortized complexity, on the other hand, usually refers to ratio of the total work done by some series of operations divided by the total number of operations performed. For example, in a dynamic array that doubles its size whenever more space is needed, each individual append operation might do O(n) work copying the array and transferring elements over. However, in doing so, it makes the next n operations complete in time O(1) because space is guaranteed to be available. Consequently, any n appends takes time O(n) total, so the amortized cost of each operation is O(1); this is the ratio of the total work (O(n)) to the number of operations (n).
The two concepts may seem similar, but they represent fundamentally different concepts. Average complexity refers to the amount of work on average given that there is an underlying probability distribution of runtimes. Amortized complexity refers to the average amount of work done by a series of operations based on the fact that certain operations are "expensive" but can be paid for by "cheaper" operations. This is why some data structures (for example, chained hash tables with rehashing) have operations that take O(1) amortized time in the average case - on average, any sequence of n operations on the data structure will take O(n) time.
As to your next question - doubling versus incremental growth - the doubling strategy ensures O(1) amortized complexity for push operations while the incremental growth strategy does not. Intuitively, if you double the size of the array when you need more space, then after doing work to copy n elements to an array of size 2n, the next n pushes will be "cheap" because space will be available. Consequently, any series of n operations take O(n) time and all operations take amortized O(1) time. With some trickier math, you can show that growing by any factor greater than one will lead to O(1) amortized time.
Incremental growth, on the other hand, doesn't guarantee this. Think of it this way - if you grow by adding k elements to the array and have an array of size 10000k, then when growing you'll do 10000k work to make the next k operations fast. After doing those k operations "cheaply," you have to do 10001k work to grow the array again. You can show that this will take Θ(n2) work over a series of n pushes, which is why it's not recommended.
Finally, you asked about arrays versus linked lists. When using linked lists, you don't need to worry about doubling or incremental growth because you can efficiently (in O(1)) allocate new linked list cells and chain them on. They're worst-case efficient structures rather than amortized efficient structures, though the constant factors are higher.
Hope this helps!