2017-12-13 9 views
0

番号1,2,4,3,5,6,の配列があるとします。ヒープソートを使用して1,3,5,7,2,4,6を印刷したいとします。 私は基本的なヒープソートを修正しようとしていましたが、正しい出力ができませんでした。最初に奇数の順番を印刷して、それよりも小さい番号の代わりにヒープソートを使用して印刷する方法はありますか?

助けてもらえますか?

#include<bits/stdc++.h> 
using namespace std; 

int heapsize; 

int make_left(int i) 
{ 
    return 2*i; 
} 
int make_right(int i) 
{ 
    return (2*i)+1; 
} 
void max_heapify(int a[],int i) 
{ 
    // cout<<heapsize<<endl; 
    int largest=i; 
    // printf("current position of largest is %d and largest is %d\n",largest,a[largest]); 


    int l=make_left(i); 
    int r=make_right(i); 
// printf("current position of left is %d and left element is %d\n",l,a[l]); 
    // printf("current position of right is %d and right element is %d\n",r,a[r]); 

    if(a[l]>=a[largest] && l<=heapsize && a[l]%2!=0) 
     largest=l; 
    if(a[r]>a[largest] && r<=heapsize && a[l]%2!=0) 
     largest=r; 
    //printf("Finalcurrent position of largest is %d and largest is %d\n",largest,a[largest]); 

    if(largest!=i) 
    { 
     swap(a[i],a[largest]); 
     max_heapify(a,largest); 
    } 
} 
void buildmax(int a[],int n) 
{ 
for (int i=n/2;i>=1;i--) 
    { 
    // printf("main theke call\n"); 
     max_heapify(a,i); 
    } 
} 
void heapsort(int a[],int n) 
{ 
    buildmax(a,n); 
// printf("After being buildmax\n"); 
    // for (int i=1;i<=n;i++) 
    //{ 
     //printf("i is %d\n",i); 
     // cout<<a[i]<<endl; 

    //} 
    for (int i=n;i>=2;i--) 
    { 
     // printf("1st element is %d and last elemenet is %d\n",a[1],a[heapsize]); 

     swap(a[1],a[heapsize]); 
     //printf("1st element is %d and last elemenet is %d\n",a[1],a[heapsize]); 
     heapsize--; 
     max_heapify(a,1); 
    } 

} 


int main() 
{ 

    int n; 
    cin>>n; 
    heapsize=n; 

    int a[n]; 
    printf("The elements are\n"); 
    for (int i=1;i<=n;i++) 
    { 
     cin>>a[i]; 
    } 
    heapsort(a,n); 

    printf("After being sorted\n"); 
    for (int i=1;i<=n;i++) 
    { 
     //printf("i is %d\n",i); 
     cout<<a[i]<<endl; 
    } 
} 
+0

を何ですか具体的な問題?あなたのコードを投稿してください! – MrSmith42

+0

私はアイデアを探していました。しかし、編集してコードを投稿しました –

+1

奇数が常に偶数になるように比較ルールを変更するだけです。 (下位ビットに辞書編集ソートを使用してから値を設定します)。 –

答えて

4

あなたは、新しい機能でどこでも単なるオペレーター未満(またはあなたが比較のためにあることを使用している場合よりも大きい)を置き換える、前と同じヒープソートのアルゴリズムを使用することができます。

bool LessThan(int a, int b) 
{ 
    if (a%2 == 1 && b%2 == 0) 
    return true; 
    if (a%2 == 0 && b%2 == 1) 
    return false; 
    return a < b; 
} 
関連する問題