簡體   English   中英

使用指針訪問類中存在的數組

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM