0

array2 の並べ替え順序に基づいて、array1 の要素を並べ替えようとしています。私の場合、array1 と array2 の両方が同じクラスのメンバーであり、パブリックです。クラス内でネストされたクラスを使用して std::sort の compare() 関数をファンクターとして記述し、ネストされたクラスが array2 にアクセスできるようにしようとしています。コードは次のとおりです。

#include <iostream>
#include <algorithm>

using namespace std;

class sort_test {
public:
  sort_test() { //some initialization
  }

  int array1[10];
  int array2[10]; 
  int index[10];

  void sorting() {
    sort (index, index+5, sort_test::Compare());
  }

  class Compare {
    public:
      sort_test *s;
      bool operator() (const int i, const int j) {
        return (s->array2[i] < s->array2[j]);
      }
  };
};

int main(void) {
    int res[5];
    sort_test st;

    st.array2[0] = 2;
    st.array2[1] = 1;
    st.array2[2] = 7;
    st.array2[3] = 5;
    st.array2[4] = 4;

    st.array1[0] = 8;
    st.array1[1] = 2;
    st.array1[2] = 3;
    st.array1[3] = 2;
    st.array1[4] = 5;

    for (int i=0 ; i<5 ; ++i) {
        st.index[i] = i;
    }

    st.sorting();

    for (int i=0 ; i<5; ++i) {
        res[i] = st.array1[st.index[i]];
    }

    for (int i=0; i<5; ++i) {
        cout << res[i] << endl;
    }

    return 0;
}

コードは正常にコンパイルされますが、セグメンテーション エラーが発生します。コードの期待される出力は 2 8 5 2 3 です

4

2 に答える 2

1

比較演算子が、初期化されていないポインターを逆参照していますs。その場合、例外が発生する可能性があります。

于 2013-03-07T23:39:59.217 に答える