C How to Program (8th Edition)
C How to Program (8th Edition)
8th Edition
ISBN: 9780133976892
Author: Paul J. Deitel, Harvey Deitel
Publisher: PEARSON
bartleby

Videos

Textbook Question
Book Icon
Chapter D, Problem D.5E

(Recursive Selection Sort) A selection sort searches an array looking for the smallest element in the array. When that element is found, it’s swapped with the first element of the array. The process is then repeated for the subarray, beginning with the second element. Each pass of the array results in one element being placed in its proper location. This sort requires processing capabilities similar to those of the bubble sort—for an array of n elements, n 1 passes must be made, and for each subarray, n 1 comparisons must be made to find the smallest value. When the subarray being processed contains one element, the array is sorted. Write a recursive function selectionsort to perform this algorithm.

Expert Solution & Answer
Check Mark
Program Plan Intro

Program Plan-

  • Define Header files.
  • Define selectionSort()function.
    • Define local variables.
    • Checking the condition using for() loop till the iteration i is less than 6.
    • Display result.
    • Checking the condition using if-else() loop.
    • Checking the second element with first element.
  • Declare main() function.
  • Declare local variable.
  • Checking the condition using for() loop till the iteration i is less than 6
  • Calling selectionSort() function.
  • Return successfully to main().

Summary Introduction- (Recursive Selection Sort)A selection sort searches an array looking for the smallest element in the array. When the element is found, it is swapped with the first element of the array. The process is repeated for the sub-array beginning with the second element of the array. Each pass of the array results in one element being placed in its proper location. This sort requires processing capabilities similar to those of bubble sort.

Program Description- The purpose of the program is to implement the recursive selection sort.

Explanation of Solution

Modified program:

/*
 *This program to implement the recursive selection sort.
*/

#include<stdio.h>

//recursive definition for selcetion sort
void selectionSort ( int a[], int size, int i, int j)
{
    //declare local variable
    int temp;
    //checking the condtion using if-else loop
    if(i==size)
    {
        //iteration gets executed till value of i is less than 6
        for(i=0; i<6; i++)

            //Displaying result
            printf("%d ",a[i]);
        return; //return successfully
    }
    else
    {
        //checking the condition using if-else() loop
        if(j<size)
        {
//checking the second element with first //element
            if(a[i]>a[j])
            {
                temp=a[i];
                a[i]=a[j];
                a[j]=temp;
            }

//function call
//calling function with parameters
            selectionSort(a,size,i,j+1);
        }

        else
        {
//function call
            selectionSort(a,size,i+1,i+1);
        }
    }
}
//Define main() function
int main(int argc, char *argv[])
{
//Declare local variables
    int arr[6],i,min,j,temp;
    printf("Enter the elements of array\n");

//Asking user to enter elements
//Executing for() loop
    for (i=0; i<6; i++)
    {
        printf("Element %d: ",i+1);
        scanf("%d",&arr[i]);
    }
//sorting the value
    selectionSort(arr,6,0,1);

    return 0; //return successfully
}

Sample Output-

Sample Output:

Enter the element of array

Element 1:37

Element 2:2

Element 3:6

Element 4:4

Element 5:89

Element 6:8

2 4 6 8 37 89

Want to see more full solutions like this?

Subscribe now to access step-by-step solutions to millions of textbook problems written by subject matter experts!
Students have asked these similar questions
Sorting is a basic issue with arrays in which the goal is to find the target element in the array. Choose from the following options: False
ARRAY RANDOMIZER Create a program that shuffels all the elements present in an array. To shuffle an array, you need to do at least 500 random swaps of any elements in the array given below. Print the shuffled array in the output. {12, 54, 22, 100, -3, 5, 10, -33, 78, 90, 29, -45, 77, -9, 19, 21} Language: CPP
In C++: Trace all the passes for the selection sort on the array: {22, 65, 9, 15, 55, 27, 33, 45}
Knowledge Booster
Background pattern image
Computer Science
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
SEE MORE QUESTIONS
Recommended textbooks for you
Text book image
Database System Concepts
Computer Science
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:McGraw-Hill Education
Text book image
Starting Out with Python (4th Edition)
Computer Science
ISBN:9780134444321
Author:Tony Gaddis
Publisher:PEARSON
Text book image
Digital Fundamentals (11th Edition)
Computer Science
ISBN:9780132737968
Author:Thomas L. Floyd
Publisher:PEARSON
Text book image
C How to Program (8th Edition)
Computer Science
ISBN:9780133976892
Author:Paul J. Deitel, Harvey Deitel
Publisher:PEARSON
Text book image
Database Systems: Design, Implementation, & Manag...
Computer Science
ISBN:9781337627900
Author:Carlos Coronel, Steven Morris
Publisher:Cengage Learning
Text book image
Programmable Logic Controllers
Computer Science
ISBN:9780073373843
Author:Frank D. Petruzella
Publisher:McGraw-Hill Education
1.1 Arrays in Data Structure | Declaration, Initialization, Memory representation; Author: Jenny's lectures CS/IT NET&JRF;https://www.youtube.com/watch?v=AT14lCXuMKI;License: Standard YouTube License, CC-BY
Definition of Array; Author: Neso Academy;https://www.youtube.com/watch?v=55l-aZ7_F24;License: Standard Youtube License