ここに書いたクイックソートがあります:
void swap(int& a, int& b);
int mid(int lo, int hi);
// My quicksort implementation
void sort(int vec[], int lo, int hi)
{
int mid;
if (hi > lo) {
int i = lo + 1;
int j = hi;
int p = mid(lo, hi);
swap(vec[lo], vec[p]);
mid = vec[lo];
while (i < j) {
if (vec[i] <= mid) {
i++;
} else {
while (i < --j && vec[j] >= mid);
swap(vec[i], vec[j]);
}
}
i++;
swap(vec[lo], vec[i]);
sort(vec, lo, i);
sort(vec, j, hi);
}
}
void swap(int& a, int& b)
{
int temp = a;
a = b;
b = temp;
}
int mid(int lo, int hi)
{
return lo + ((hi - lo) / 2);
}
g++ -g -c array.cpp -o array.o
を使用してオブジェクトファイルにコンパイルしようとしましたが、このエラーが発生します。
array.cpp:24:14: error: called object type 'int' is not a function or function
pointer
int p = mid(lo, hi);
~~~^
1 error generated.
すべてが正しいように見えます。誰が私が間違っているかを理解するのを助けることができますか?
ローカル変数mid
は、使用ポイントにより近いスコープで宣言されているため、mid()
関数を「シャドウ」します。コンパイラは、無効な整数を「呼び出し」ようとしていると考えます。この問題を修正するには、ローカル変数の名前を変更します。
_int midpoint;
if (hi > lo) {
int i = lo + 1;
int j = hi;
int p = mid(lo, hi);
swap(vec[lo], vec[p]);
midpoint = vec[lo];
...
}
_
注:変数の名前を変更する代わりに::mid(lo, hi)
を使用することもできますが、プログラムの読者を混乱させることになります。
_int mid(int lo, int hi); // here you declared mid as function and defined
// it later
// My quicksort implementation
void sort(int vec[], int lo, int hi)
{
int mid; // but here you declared mid as local variable
if (hi > lo) { // it will shadow int mid(int lo, int hi);
int i = lo + 1;
int j = hi;
int p = mid(lo, hi); // so this is error, mid is integer not a function
_
アルゴリズム内の変数の名前を変更するか、スコープ解決演算子::mid(lo, hi)
を使用して、以前にグローバルスコープで定義されたmid
関数にアクセスできます。