Skip to main content

Heap sort using Divide & Conquer

#include
#include
#define MAX 30
struct heap{
 int S[MAX];
 int heapsize;
}H;
void siftdown(struct heap* H,int i)
{
 int parent,largerchild;
 int siftkey;
 int spotfound;
 siftkey=H->S[i];
 parent=i;
 spotfound=0;

 while(2*parent <= H->heapsize && spotfound==0)
 {
  if(2*parent < H->heapsize && H->S[2*parent] < H->S[2*parent+1])
   largerchild=2*parent+1;
  else
   largerchild=2*parent;

  if(siftkeyS[largerchild])
  {
   H->S[parent]=H->S[largerchild];
   parent=largerchild;
  }
  else
   spotfound=1;
 }
 H->S[parent]=siftkey;
}

int root(struct heap* H)
{
 int keyout;
 keyout=H->S[1];
 H->S[1]=H->S[H->heapsize];
 H->heapsize=H->heapsize-1;
 siftdown(H,1);
 return keyout;
}
void removekeys(int n,struct heap* H)
{
 int i;
 for(i=n;i>=1;i--)
 {
  H->S[i]=root(H);
 }
}

void makeheap(int n,struct heap* H)
{
 int i;
 H->heapsize=n;
 for(i=n/2;i>=1;i--)
  siftdown(H,i);
}
void heapsort(int n,struct heap* H)
{
 makeheap(n,H);
 removekeys(n,H);
}
void main()
{
 int n,i,j;
 clrscr();
 printf("\n-------------------------------------------------");
 printf("\n               HEAP SORT USING D & C");
 printf("\n-------------------------------------------------");
 printf("\n Enter number of element you want:");
 scanf("%d",&n);
 for(i=1;i<=n;i++)
 {
  scanf("%d",&H.S[i]);
 }
 heapsort(n,&H);
 printf("\n-------------------------------------------------");
 printf("\n Elements after sorting:");
 for(i=1;i<=n;i++)
 {
        printf("%3d",H.S[i]);
 }
 printf("\n-------------------------------------------------");
getch();
}

OUTPUT

------------------------------------------------------------------------------------
               HEAP SORT USING D & C
------------------------------------------------------------------------------------
 Enter number of element you want:8
11
95
25
74
36
12
10
45

------------------------------------------------------------------------------------
 Elements after sorting: 10 11 12 25 36 45 74 95
------------------------------------------------------------------------------------

Comments

  1. hey, can you explain me, what is "spotfound", "siftdown", "siftkey", and "keyout" ???
    thanks

    ReplyDelete
  2. Harrah's Casino and Hotel - Jordan 10 Retro Outlet
    Harrah's Casino where can you buy air jordan 18 retro varsity red and Hotel, air jordan 18 retro red shipping owned by Vici Properties, Inc., is an indian casino and hotel located find air jordan 18 retro racer blue in West Virginia. It how can i buy air jordan 18 retro toro mens sneakers is located in West Virginia and 토토 커뮤니티 is

    ReplyDelete

Post a Comment

Popular posts from this blog

MVT (Multiprogramming Variable Task) in C Programming

#include #include void main() { int i,os_m,nPage,total,pg[25]; clrscr(); printf("\nEnter total memory size:"); scanf("%d",&total); printf("\nEnter memory for OS:"); scanf("%d",&os_m); printf("\nEnter no. of pages:"); scanf("%d",&nPage); for(i=0;i =pg[i]) { printf("\n Allocate page %d",i+1); total=total-pg[i]; } else printf("\n page %d is not allocated due to insufficient memory.",i+1); } printf("\n External Fragmentation is:%d",total); getch(); } OUTPUT Enter total memory size:1024 Enter memory for OS:256 Enter no. of pages:4 Enter size of page[1]:128 Enter size of page[2]:512 Enter size of page[3]:64 Enter size of page[4]:512 Allocate page 1 Allocate page 2 Allocate page 3 page 4 is not allocated due to insufficient memory. External Fragmentation is:64

First Come First Serve (FCFS) Page replacement algorithm in C Programming

#include #include int fsize; int frm[15]; void display(); void main() { int pg[100],nPage,i,j,pf=0,top=-1,temp,flag=0; clrscr(); printf("\n Enter frame size:"); scanf("%d",&fsize); printf("\n Enter number of pages:"); scanf("%d",&nPage); for(i=0;i OUTPUT Enter frame size:3 Enter number of pages:12 Enter page[1]:1 Enter page[2]:2 Enter page[3]:3 Enter page[4]:4 Enter page[5]:1 Enter page[6]:2 Enter page[7]:5 Enter page[8]:1 Enter page[9]:2 Enter page[10]:3 Enter page[11]:4 Enter page[12]:5 page | Frame content -------------------------------------- 1 | 1 -1 -1 2 | 1 2 -1 3 | 1 2 3 4 | 4 2 3 1 | 4 1 3 2 | 4 1 2 5 | 5 1 2 1 | 5 1 2 2 | 5 1 2 3 | 5 3 2 4 | 5 3 4 5 | 5 3 4 ---------------------------...

Deadlock Prevention using Banker’s Algorithm in C Programming

#include #include void main() { int allocated[15][15],max[15][15],need[15][15],avail[15],tres[15],work[15],flag[15]; int pno,rno,i,j,prc,count,t,total; count=0; clrscr(); printf("\n Enter number of process:"); scanf("%d",&pno); printf("\n Enter number of resources:"); scanf("%d",&rno); for(i=1;i OUTPUT Enter number of process:5 Enter number of resources:3 Enter total numbers of each resources:10 5 7 Enter Max resources for each process: for process 1:7 5 3 for process 2:3 2 2 for process 3:9 0 2 for process 4:2 2 2 for process 5:4 3 3 Enter allocated resources for each process: for process 1:0 1 0 for process 2:3 0 2 for process 3:3 0 2 for process 4:2 1 1 for process 5:0 0 2 available resources: 2 3 0 Allocated matrix Max need 0 1 0| 7 5 3| 7 4 3 3 0 2| 3 2 2| 0 2 0 3 0 2| 9 0 2| 6 0 0 2 1 1| ...