Fehler "Pindex" wurde in diesem Bereich nicht deklariert. (Linie 15)
Auch, was ist der Unterschied zwischen erklärt das Array in der Funktion mitFehler in Quick Sort-Programm
int a[]
und
int a*
Und einige Ressourcen für explainatio von Sortieralgorithmen vor.
#include<iostream>
using namespace std;
int Partition(int a[], int start, int last);
void QuickSort(int a[], int start, int last)
{
/*if(start>=last)
{
return ;
}*/
{ if(start<last)
int Pindex=Partition(a, start, last);
QuickSort(a, start, Pindex-1);
QuickSort(a,Pindex+1, last);
}
}
int Partition(int a[] ,int start, int last)
{
int temp;
int Pindex=start;
int pivot=a[last];
for (int i=0;i<last;i++)
{
if(a[i]<=pivot)
{
temp=a[i];
a[i]=a[Pindex];
a[Pindex]=temp;
Pindex++;
}
}
temp=a[Pindex];
a[Pindex]=a[last];
a[last]=temp;
return Pindex;
}
int main()
{
int n;
cout<<"\n Enter the no of elements ";
cin>>n;
cout<<"\n Enter the elements ";
int A[n];
for (int i=0;i<n;i++)
{
cin>>A[i];
}
QuickSort(A,0,n-1);
cout<<"\n Sorted Array ";
for (int i=0;i<n;i++)
{
cout<<A[i];
}
return 0;
}
'Pindex 'wird nur im Rahmen der' if'-Anweisung deklariert. Dies wäre klar, wenn Sie geschweifte Klammern hinzufügen: 'if (start
Als Funktionsparameter gibt es absolut keinen Unterschied zwischen' int a [] 'und' int * a'. Sie können die Funktion sogar in eine Richtung deklarieren und dann anders definieren. –
a * gibt einen Fehler. * a ist ein Zeiger. a [10] ist ein Array. – stark