C How To Program, Global Edition
C How To Program, Global Edition
8th Edition
ISBN: 9781292110974
Author: Paul 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
What are the major threats of using the internet? How do you use it? How do children use it? How canwe secure it? Provide four references with your answer. Two of the refernces can be from an article and the other two from websites.
Assume that a string of name & surname is saved in S. The alphabetical characters in S can be in lowercase and/or uppercase letters. Name and surname are assumed to be separated by a space character and the string ends with a full stop "." character. Write an assembly language program that will copy the name to NAME in lowercase and the surname to SNAME in uppercase letters. Assume that name and/or surname cannot exceed 20 characters. The program should be general and work with every possible string with name & surname. However, you can consider the data segment definition given below in your program. .DATA S DB 'Mahmoud Obaid." NAME DB 20 DUP(?) SNAME DB 20 DUP(?) Hint: Uppercase characters are ordered between 'A' (41H) and 'Z' (5AH) and lowercase characters are ordered between 'a' (61H) and 'z' (7AH) in the in the ASCII Code table. For lowercase letters, bit 5 (d5) of the ASCII code is 1 where for uppercase letters it is 0. For example, Letter 'h' Binary ASCII 01101000 68H 'H'…
What did you find most interesting or surprising about the scientist Lavoiser?
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
Programming Logic & Design Comprehensive
Computer Science
ISBN:9781337669405
Author:FARRELL
Publisher:Cengage
Text book image
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781337671385
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT
Text book image
C++ for Engineers and Scientists
Computer Science
ISBN:9781133187844
Author:Bronson, Gary J.
Publisher:Course Technology Ptr
Text book image
C++ Programming: From Problem Analysis to Program...
Computer Science
ISBN:9781337102087
Author:D. S. Malik
Publisher:Cengage Learning
Text book image
Microsoft Visual C#
Computer Science
ISBN:9781337102100
Author:Joyce, Farrell.
Publisher:Cengage Learning,
Text book image
New Perspectives on HTML5, CSS3, and JavaScript
Computer Science
ISBN:9781305503922
Author:Patrick M. Carey
Publisher:Cengage Learning
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