http://en.cppreference.com/w/cpp/algorithm/binary_searchを熟読しているときに、前方反復子を引数として取ることに気付きました。むしろランダムアクセスイテレータの方がいいと思っていたので、今は混乱しています。そのため、バイナリ検索は実際にはバイナリになります。
私の好奇心を満たすために、私は小さなプログラムを書きました:
#include <iostream>
#include <vector>
#include <forward_list>
#include <list>
#include <deque>
#include <algorithm>
#include <chrono>
#include <random>
int main()
{
std::uniform_int_distribution<int> uintdistr(-4000000, 4000000);
std::mt19937 twister(std::chrono::high_resolution_clock::to_time_t(std::chrono::high_resolution_clock::now()));
size_t arr[] = { 200000, 400000, 800000, 1600000, 3200000, 6400000, 12800000 };
for(auto size : arr)
{
std::list<int> my_list;
for(size_t i = 0; i < size; i++)
my_list.push_front(uintdistr(twister));
std::chrono::time_point<std::chrono::high_resolution_clock> start, end;
my_list.sort(); //fixed
start = std::chrono::high_resolution_clock::now();
std::binary_search(my_list.begin(), my_list.end(), 1252525);
end = std::chrono::high_resolution_clock::now();
long long unsigned elapsed_time = std::chrono::duration_cast<std::chrono::microseconds>(end-start).count();
std::cout << "Test finished in " << elapsed_time << "\n";
}
}
gcc 4.7.0 でコンパイルして実行する
g++ -std=c++11 test.cpp
私のマシンで次の結果を提供します:
Test finished in 0
Test finished in 15625
Test finished in 15625
Test finished in 46875
Test finished in 93750
Test finished in 171875
Test finished in 312500
そのため、実際には転送リストでバイナリ検索を実行していないようです。今私の質問は次のとおりです。
なんでこんな紛らわしい名前?
このようなコードが許可されるのはなぜですか?
参照が「最初と最後の間の距離の対数」であると言っているのはなぜですか?
標準はそれについて何を言わなければなりませんか?
編集:コードは検索の前にリストをソートします-愚かな間違い、結果は次のようになります:
Test finished in 46875
Test finished in 109375
Test finished in 265625
Test finished in 546875
Test finished in 1156250
Test finished in 2625000
Test finished in 6375000
もちろん、まだ対数ではありません;)