SlideShare uma empresa Scribd logo
1 de 10
CHAPTER 6 Sorting and Selection
Algorithm 6.1.2 Insertion Sort This algorithm sorts the array  a  by first inserting  a [2] into the sorted array  a [1]; next inserting  a [3] into the sorted array  a [1],  a [2]; and so on; and finally inserting  a [ n ] into the sorted array  a [1], ... ,  a [ n  - 1]. Input Parameters:  a Output Parameters: None insertion_sort ( a ) { n  =  a . last for  i  = 2 to  n  { val  =  a [ i ]  // save  a [ i ] so it can be inserted  j  =  i  – 1 // into the correct place // if  val  <  a [ j ],move  a [ j ] right to make room for  a [ i ] while ( j  ≥ 1 &&  val  <  a [ j ]) { a [ j  + 1] =  a [ j ] j  =  j  - 1 } a [ j  + 1] =  val  // insert  val } }
Algorithm 6.2.2 Partition This algorithm partitions the array a [ i ], ... ,  a [ j ] by inserting  val   =  a [ i ] at the index  h  where it would be if the array was sorted. When the algorithm concludes, values at indexes less than  h  are less than  val , and values at indexes greater than  h  are greater than or equal to  val . The algorithm returns the index  h . Input Parameters:  a , i , j Output Parameters:  i partition ( a , i , j ) { val  =  a [ i ] h  =  i for  k  =  i  + 1 to  j if ( a [ k ] <  val ) { h  =  h  + 1 swap ( a [ h ], a [ k ]) } swap  ( a [ i ], a [ h ]) return  h }
Algorithm 6.2.4 Quicksort This algorithm sorts the array a [ i ], ... ,  a [ j ] by using the partition algorithm (Algorithm 6.2.2). Input Parameters:  a , i , j Output Parameters:  i quicksort ( a , i , j ) { if ( i  <  j ) { p  =  partition ( a , i , j ) quicksort ( a , i , p  - 1) quicksort ( a , p  + 1, j ) } }
Algorithm 6.2.6 Random Partition This algorithm partitions the array a [ i ], ... ,  a [ j ] by inserting  val   =  a [ i ] at the index  h  where it would be if the array was sorted. The index  k  is chosen randomly. We assume that the function rand ( i , j ) executes in constant time and returns a random integer between  i  and  j  , inclusive. After inserting  val  at index  h , values at indexes less than  h  are less than  val , and values at indexes greater than  h  are greater than or equal to  val . The algorithm returns the index  h . Input Parameters:  a , i , j Output Parameters:  i random_partition ( a , i , j ) { k  =  rand [ i , j ] swap  ( a [ i ], a [ k ]) return  partition ( i , j ) // Algorithm 6.2.2 }
Algorithm 6.2.7 Random Quicksort This algorithm sorts the array a [ i ], ... ,  a [ j ] by using the random partition algorithm (Algorithm 6.2.6). Input Parameters:  a , i , j Output Parameters:  i random _ quicksort ( a , i , j ) { if ( i  <  j ) { p  =  random _ partition ( a , i , j ) random _ quicksort ( a , i , p  - 1) random _ quicksort ( a , p  + 1, j ) } }
Algorithm 6.4.2 Counting Sort This algorithm sorts the array a [1], ... ,  a [ n ] of integers, each in the range 0 to  m , inclusive.
Input Parameters:  a , m Output Parameters:  a counting_sort ( a , m ) { // set  c [ k ] = the number of occurrences of value  k   // in the array  a . // begin by initializing  c  to zero. for  k  = 0 to  m c [ k ] = 0 n  =  a . last for  i  = 1 to  n c [ a [ i ]] =  c [ a [ i ]] + 1 // modify  c  so that  c [ k ] = number of elements ≤  k for k = 1 to  m c [ k ] =  c [ k ] +  c [ k  - 1] // sort a with the result in  b for  i  =  n  downto 1 { b [ c [ a [ i ]]] =  a [ i ]   c [ a [ i ]] =  c [ a [ i ]] - 1 } // copy  b  back to  a for  i  = 1 to  n a [ i ] =  b [ i ] }
Algorithm 6.4.4 Radix Sort This algorithm sorts the array a [1], ... ,  a [ n ] of integers. Each integer has at most  k  digits. Input Parameters:  a , k Output Parameters:  a radix_sort ( a , k ) { for  i  = 0 to  k  - 1 counting_sort ( a ,10) // key is digit in 10 i ’s place }
Algorithm 6.5.2 Random Select Let  val  be the value in the array  a [ i ], ... ,  a [ j ] that would be at index  k  ( i   ≤   k   ≤   j  ) if the entire array was sorted. This algorithm rearranges the array so that  val  is at index  k , all values at indexes less than  k  are less than  val , and all values at indexes greater than  k  are greater than or equal to  val . The algorithm uses the random-partition algorithm (Algorithm 6.2.6). Input Parameters:  a , i , j , k Output Parameter:  a random_select ( a , i , j , k ) { if ( i  <  j ) { p  =  random_partition ( a , i , j ) if ( k  ==  p ) return if ( k  <  p ) random_select ( a , i , p  - 1, k ) else random_select ( a , p  + 1, j , k ) } }

Mais conteúdo relacionado

Mais procurados

Linear Regression Parameters
Linear Regression ParametersLinear Regression Parameters
Linear Regression Parameters
camposer
 

Mais procurados (18)

Algorithms - "heap sort"
Algorithms - "heap sort"Algorithms - "heap sort"
Algorithms - "heap sort"
 
Algorithm analysis basics - Seven Functions/Big-Oh/Omega/Theta
Algorithm analysis basics - Seven Functions/Big-Oh/Omega/ThetaAlgorithm analysis basics - Seven Functions/Big-Oh/Omega/Theta
Algorithm analysis basics - Seven Functions/Big-Oh/Omega/Theta
 
Algorithms - "quicksort"
Algorithms - "quicksort"Algorithms - "quicksort"
Algorithms - "quicksort"
 
Dsa circular queue
Dsa circular queueDsa circular queue
Dsa circular queue
 
Lec3
Lec3Lec3
Lec3
 
Counting sort(Non Comparison Sort)
Counting sort(Non Comparison Sort)Counting sort(Non Comparison Sort)
Counting sort(Non Comparison Sort)
 
Greedy method
Greedy method Greedy method
Greedy method
 
Bucket sort- A Noncomparision Algorithm
Bucket sort- A Noncomparision AlgorithmBucket sort- A Noncomparision Algorithm
Bucket sort- A Noncomparision Algorithm
 
Queue
QueueQueue
Queue
 
Linear Regression Parameters
Linear Regression ParametersLinear Regression Parameters
Linear Regression Parameters
 
Chap04alg
Chap04algChap04alg
Chap04alg
 
Chap04alg
Chap04algChap04alg
Chap04alg
 
Detalied information of queue
Detalied information of queueDetalied information of queue
Detalied information of queue
 
A sorted linear array
A sorted linear array A sorted linear array
A sorted linear array
 
MATLAB for Technical Computing
MATLAB for Technical ComputingMATLAB for Technical Computing
MATLAB for Technical Computing
 
Data Structures - Searching & sorting
Data Structures - Searching & sortingData Structures - Searching & sorting
Data Structures - Searching & sorting
 
Algebraic Approach to Implementing an ATL Model Checker
Algebraic Approach to Implementing an ATL Model CheckerAlgebraic Approach to Implementing an ATL Model Checker
Algebraic Approach to Implementing an ATL Model Checker
 
R: Apply Functions
R: Apply FunctionsR: Apply Functions
R: Apply Functions
 

Destaque

8 elementary sorts-insertion
8 elementary sorts-insertion8 elementary sorts-insertion
8 elementary sorts-insertion
irdginfo
 
Berenschot persetatie Succesvol Aanbesteden 051010
Berenschot persetatie Succesvol Aanbesteden 051010Berenschot persetatie Succesvol Aanbesteden 051010
Berenschot persetatie Succesvol Aanbesteden 051010
Johan Stuiver
 
Raporti Mbi Shqiperine ... Raport Su Albania
Raporti Mbi Shqiperine ... Raport Su AlbaniaRaporti Mbi Shqiperine ... Raport Su Albania
Raporti Mbi Shqiperine ... Raport Su Albania
Aleks Sandro
 
GTS Website
GTS WebsiteGTS Website
GTS Website
Chuckcoe
 
EXAMPLE UNIT 1
EXAMPLE UNIT 1EXAMPLE UNIT 1
EXAMPLE UNIT 1
marina1982
 

Destaque (20)

Insertion sort
Insertion sortInsertion sort
Insertion sort
 
c-programming-using-pointers
c-programming-using-pointersc-programming-using-pointers
c-programming-using-pointers
 
8 elementary sorts-insertion
8 elementary sorts-insertion8 elementary sorts-insertion
8 elementary sorts-insertion
 
sort search in C
 sort search in C  sort search in C
sort search in C
 
Sorting techniques Anil Dutt
Sorting techniques Anil DuttSorting techniques Anil Dutt
Sorting techniques Anil Dutt
 
Insertion Sort Algorithm
Insertion Sort AlgorithmInsertion Sort Algorithm
Insertion Sort Algorithm
 
Berenschot persetatie Succesvol Aanbesteden 051010
Berenschot persetatie Succesvol Aanbesteden 051010Berenschot persetatie Succesvol Aanbesteden 051010
Berenschot persetatie Succesvol Aanbesteden 051010
 
Chap12alg
Chap12algChap12alg
Chap12alg
 
Lecture915
Lecture915Lecture915
Lecture915
 
Raporti Mbi Shqiperine ... Raport Su Albania
Raporti Mbi Shqiperine ... Raport Su AlbaniaRaporti Mbi Shqiperine ... Raport Su Albania
Raporti Mbi Shqiperine ... Raport Su Albania
 
Cei week 2
Cei week 2Cei week 2
Cei week 2
 
Tavve Zone Ranger
Tavve   Zone RangerTavve   Zone Ranger
Tavve Zone Ranger
 
GTS Website
GTS WebsiteGTS Website
GTS Website
 
Pirates v. Mercenaries: Purely Private Transnational Violence at the Margins ...
Pirates v. Mercenaries: Purely Private Transnational Violence at the Margins ...Pirates v. Mercenaries: Purely Private Transnational Violence at the Margins ...
Pirates v. Mercenaries: Purely Private Transnational Violence at the Margins ...
 
CUEB Presentation
CUEB PresentationCUEB Presentation
CUEB Presentation
 
Berenschot presentatie Metaalunie Noord NL Samenwerken & aanbesteden
Berenschot presentatie Metaalunie Noord NL Samenwerken & aanbestedenBerenschot presentatie Metaalunie Noord NL Samenwerken & aanbesteden
Berenschot presentatie Metaalunie Noord NL Samenwerken & aanbesteden
 
2010 Training And Educational Offerings For Northern Ohio’S
2010 Training And Educational Offerings For Northern Ohio’S2010 Training And Educational Offerings For Northern Ohio’S
2010 Training And Educational Offerings For Northern Ohio’S
 
Hybrid worlds fungi progression 2 - crews
Hybrid worlds   fungi progression 2 - crewsHybrid worlds   fungi progression 2 - crews
Hybrid worlds fungi progression 2 - crews
 
EXAMPLE UNIT 1
EXAMPLE UNIT 1EXAMPLE UNIT 1
EXAMPLE UNIT 1
 
Python
PythonPython
Python
 

Semelhante a Chap06alg

Semelhante a Chap06alg (20)

Chap08alg
Chap08algChap08alg
Chap08alg
 
Chap08alg
Chap08algChap08alg
Chap08alg
 
Algorithms - "Chapter 2 getting started"
Algorithms - "Chapter 2 getting started"Algorithms - "Chapter 2 getting started"
Algorithms - "Chapter 2 getting started"
 
Computation of Semi-Magic Squares Generated by Serpentine Matrices
Computation of Semi-Magic Squares Generated by Serpentine MatricesComputation of Semi-Magic Squares Generated by Serpentine Matrices
Computation of Semi-Magic Squares Generated by Serpentine Matrices
 
Chap05alg
Chap05algChap05alg
Chap05alg
 
Chap05alg
Chap05algChap05alg
Chap05alg
 
Arrays
ArraysArrays
Arrays
 
Chap11alg
Chap11algChap11alg
Chap11alg
 
Chap11alg
Chap11algChap11alg
Chap11alg
 
Array
ArrayArray
Array
 
Leet Code May Coding Challenge - DataStructure and Algorithm Problems
Leet Code May Coding Challenge - DataStructure and Algorithm ProblemsLeet Code May Coding Challenge - DataStructure and Algorithm Problems
Leet Code May Coding Challenge - DataStructure and Algorithm Problems
 
ARRAY OPERATIONS.pptx
ARRAY OPERATIONS.pptxARRAY OPERATIONS.pptx
ARRAY OPERATIONS.pptx
 
sorting1.pptx
sorting1.pptxsorting1.pptx
sorting1.pptx
 
Introduction to Algorithms
Introduction to AlgorithmsIntroduction to Algorithms
Introduction to Algorithms
 
DAA-Divide and Conquer methodology, DAA 2024
DAA-Divide and Conquer methodology, DAA 2024DAA-Divide and Conquer methodology, DAA 2024
DAA-Divide and Conquer methodology, DAA 2024
 
Chap07alg
Chap07algChap07alg
Chap07alg
 
Python programming : Arrays
Python programming : ArraysPython programming : Arrays
Python programming : Arrays
 
object oriented programming java lectures
object oriented programming java lecturesobject oriented programming java lectures
object oriented programming java lectures
 
PRACTICAL COMPUTING
PRACTICAL COMPUTINGPRACTICAL COMPUTING
PRACTICAL COMPUTING
 
SYSTEM IDENTIFICATION USING CEREBELLAR MODEL ARITHMETIC COMPUTER
SYSTEM IDENTIFICATION USING CEREBELLAR MODEL ARITHMETIC COMPUTERSYSTEM IDENTIFICATION USING CEREBELLAR MODEL ARITHMETIC COMPUTER
SYSTEM IDENTIFICATION USING CEREBELLAR MODEL ARITHMETIC COMPUTER
 

Mais de Munhchimeg (20)

Ded algorithm1
Ded algorithm1Ded algorithm1
Ded algorithm1
 
Ded algorithm
Ded algorithmDed algorithm
Ded algorithm
 
Tobch lecture1
Tobch lecture1Tobch lecture1
Tobch lecture1
 
Tobch lecture
Tobch lectureTobch lecture
Tobch lecture
 
Recursive
RecursiveRecursive
Recursive
 
Protsesor
ProtsesorProtsesor
Protsesor
 
Lecture916
Lecture916Lecture916
Lecture916
 
Lecture915
Lecture915Lecture915
Lecture915
 
Lecture914
Lecture914Lecture914
Lecture914
 
Lecture913
Lecture913Lecture913
Lecture913
 
Lecture912
Lecture912Lecture912
Lecture912
 
Lecture911
Lecture911Lecture911
Lecture911
 
Lecture910
Lecture910Lecture910
Lecture910
 
Lecture9
Lecture9Lecture9
Lecture9
 
Lecture8
Lecture8Lecture8
Lecture8
 
Lecture7
Lecture7Lecture7
Lecture7
 
Lecture6
Lecture6Lecture6
Lecture6
 
Lecture5
Lecture5Lecture5
Lecture5
 
Lecture4
Lecture4Lecture4
Lecture4
 
Lecture3
Lecture3Lecture3
Lecture3
 

Último

EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
Earley Information Science
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
giselly40
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
Joaquim Jorge
 

Último (20)

Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdf
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day Presentation
 
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 

Chap06alg

  • 1. CHAPTER 6 Sorting and Selection
  • 2. Algorithm 6.1.2 Insertion Sort This algorithm sorts the array a by first inserting a [2] into the sorted array a [1]; next inserting a [3] into the sorted array a [1], a [2]; and so on; and finally inserting a [ n ] into the sorted array a [1], ... , a [ n - 1]. Input Parameters: a Output Parameters: None insertion_sort ( a ) { n = a . last for i = 2 to n { val = a [ i ] // save a [ i ] so it can be inserted j = i – 1 // into the correct place // if val < a [ j ],move a [ j ] right to make room for a [ i ] while ( j ≥ 1 && val < a [ j ]) { a [ j + 1] = a [ j ] j = j - 1 } a [ j + 1] = val // insert val } }
  • 3. Algorithm 6.2.2 Partition This algorithm partitions the array a [ i ], ... , a [ j ] by inserting val = a [ i ] at the index h where it would be if the array was sorted. When the algorithm concludes, values at indexes less than h are less than val , and values at indexes greater than h are greater than or equal to val . The algorithm returns the index h . Input Parameters: a , i , j Output Parameters: i partition ( a , i , j ) { val = a [ i ] h = i for k = i + 1 to j if ( a [ k ] < val ) { h = h + 1 swap ( a [ h ], a [ k ]) } swap ( a [ i ], a [ h ]) return h }
  • 4. Algorithm 6.2.4 Quicksort This algorithm sorts the array a [ i ], ... , a [ j ] by using the partition algorithm (Algorithm 6.2.2). Input Parameters: a , i , j Output Parameters: i quicksort ( a , i , j ) { if ( i < j ) { p = partition ( a , i , j ) quicksort ( a , i , p - 1) quicksort ( a , p + 1, j ) } }
  • 5. Algorithm 6.2.6 Random Partition This algorithm partitions the array a [ i ], ... , a [ j ] by inserting val = a [ i ] at the index h where it would be if the array was sorted. The index k is chosen randomly. We assume that the function rand ( i , j ) executes in constant time and returns a random integer between i and j , inclusive. After inserting val at index h , values at indexes less than h are less than val , and values at indexes greater than h are greater than or equal to val . The algorithm returns the index h . Input Parameters: a , i , j Output Parameters: i random_partition ( a , i , j ) { k = rand [ i , j ] swap ( a [ i ], a [ k ]) return partition ( i , j ) // Algorithm 6.2.2 }
  • 6. Algorithm 6.2.7 Random Quicksort This algorithm sorts the array a [ i ], ... , a [ j ] by using the random partition algorithm (Algorithm 6.2.6). Input Parameters: a , i , j Output Parameters: i random _ quicksort ( a , i , j ) { if ( i < j ) { p = random _ partition ( a , i , j ) random _ quicksort ( a , i , p - 1) random _ quicksort ( a , p + 1, j ) } }
  • 7. Algorithm 6.4.2 Counting Sort This algorithm sorts the array a [1], ... , a [ n ] of integers, each in the range 0 to m , inclusive.
  • 8. Input Parameters: a , m Output Parameters: a counting_sort ( a , m ) { // set c [ k ] = the number of occurrences of value k // in the array a . // begin by initializing c to zero. for k = 0 to m c [ k ] = 0 n = a . last for i = 1 to n c [ a [ i ]] = c [ a [ i ]] + 1 // modify c so that c [ k ] = number of elements ≤ k for k = 1 to m c [ k ] = c [ k ] + c [ k - 1] // sort a with the result in b for i = n downto 1 { b [ c [ a [ i ]]] = a [ i ] c [ a [ i ]] = c [ a [ i ]] - 1 } // copy b back to a for i = 1 to n a [ i ] = b [ i ] }
  • 9. Algorithm 6.4.4 Radix Sort This algorithm sorts the array a [1], ... , a [ n ] of integers. Each integer has at most k digits. Input Parameters: a , k Output Parameters: a radix_sort ( a , k ) { for i = 0 to k - 1 counting_sort ( a ,10) // key is digit in 10 i ’s place }
  • 10. Algorithm 6.5.2 Random Select Let val be the value in the array a [ i ], ... , a [ j ] that would be at index k ( i ≤ k ≤ j ) if the entire array was sorted. This algorithm rearranges the array so that val is at index k , all values at indexes less than k are less than val , and all values at indexes greater than k are greater than or equal to val . The algorithm uses the random-partition algorithm (Algorithm 6.2.6). Input Parameters: a , i , j , k Output Parameter: a random_select ( a , i , j , k ) { if ( i < j ) { p = random_partition ( a , i , j ) if ( k == p ) return if ( k < p ) random_select ( a , i , p - 1, k ) else random_select ( a , p + 1, j , k ) } }