[英]Accessing an array present in a class using pointers
#include <iostream>
using namespace std;
class sort_overload
{
int a[10];
public:
void sort(int ,int);
void display();
void getdata();
}s;
void sort_overload::sort(int first,int last) //quick sorting
{
int sort_overload :: *sp = &sort_overload :: a[0]; //pointer to the base address of a present in class sorted_overload
sort_overload *sp_obj = &s;
int pivot = sp_obj->*(sp+last);
int i=first,j=last;
int temp;
if(i<j)
{
while((sp_obj->*(sp+i)) < pivot)
i++;
while((sp_obj->*(sp+j)) > pivot)
j--;
if(i<j)
{
temp = (sp_obj->*(sp+i));
(sp_obj->*(sp+i)) = (sp_obj->*(sp+j));
sp_obj->*(sp+j) = pivot;
sp_obj->*(sp+last)=temp;
}
}
s.sort(first,j-1);
s.sort(j+1,last);
}
void sort_overload::display()
{
int sort_overload :: *sp = &sort_overload :: a;
sort_overload *sp_obj = &s;
for(int i=0;i<10;i++)
cout<<"Sorted array numbers:"<<sp_obj->*(sp+i)<<endl;
}
void sort_overload::getdata()
{
int sort_overload:: *sp = &sort_overload :: a;
sort_overload *sp_obj = &s;
cout<<"Enter numbers";
for(int i=0;i<10;i++)
cin>>sp_obj->*(sp+i);
}
int main()
{
s.getdata();
s.sort(0,9);
s.display();
return 0;
}
這句話給我一個錯誤:
int sort_overload :: *sp = &sort_overload :: a[0];
有人可以告訴我為什么會出現錯誤嗎?
我正在嘗試對10個整數值進行排序,並進一步對其進行重載以對double和float值進行排序,但我被困在排序部分。
以來
void sort_overload::sort(int first,int last)
是您的類的成員函數,您可以通過替換來訪問數組
int sort_overload :: *sp = &sort_overload :: a[0];
通過
int *sp = this->a;
或者更好的是使用this->a
而不是sp
您不能使用語法:
&sort_overload :: a[0];
因為您的數組不是靜態屬性。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.