目次
工作HardwareHubからのお知らせ
サンプルコード
ソートされた長さ N
の配列 a_i
は有界な順序集合です。有界な順序集合には上界 upper_bound
と下界 lower_bound
があります。a_i
は upper_bound
によって上から押さえつけられています。lower_bound
によって下から押さえつけられています。
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
int a[] = {1, 2, 3, 3, 4, 5}; // ソートされていること (重要)
int n = sizeof(a) / sizeof(int);
int* lb = lower_bound(a, a + n, 3); // min(i | a[i] >= 3) となる a[i] へのポインタ
int* ub = upper_bound(a, a + n, 3); // min(i | a[i] > 3) となる a[i] へのポインタ
cout << *lb << endl; //=> 3
cout << *ub << endl; //=> 4
cout << ub - lb << endl; //=> 2 ('3' の個数; ポインタ同士の減算)
return 0;
}
関連記事
- ダウンキャスト (C++をもう一度)実行時型情報 RTTI #include <iostream> #include <typeinfo> using namespace std; class MyClass { public: virtual ~MyClass() {} // typeid で正しい RTTI // (RunTime Type Information; 実行時型情報) ...
- 競技プログラミングの基本処理チートシート (C++)限られた時間の中で問題を解くために必要となる、競技プログラミングにおける基本的な処理のチートシートです。競プロにおけるメジャー言語 C++ を利用します。その際 C++11 の機能は利用せず C++03 の機能の範囲内で記述します。 頻度高く定期的に開催されるコンテスト AtCoder Codeforces main.cpp #include <iostream>
- 構造体と列挙体 (C++をもう一度)構造体 #include <iostream> using namespace std; struct MyStruct { char charval; int intval; }; void Show(MyStruct* obj) { cout << obj->intval << endl; } int main() { ...
- Valgrind による C/C++ メモリリーク検出JVM メモリリークでは JDK の jstat や jmap で原因を調査できます。C/C++ では valgrind の Memcheck ツールが利用できます。valgrind には複数のツールが含まれており既定のツールが Memcheck です。他のツールを利用する場合は --tool オプションで指定します。 [簡単な利用例](h
- クラスの基本/初期化 (C++をもう一度)構造体のように初期化する (非推奨) #include <iostream> using namespace std; const int MAX_STR = 16; class MyClass { public: int m_integer; char m_str[MAX_STR + 1]; void Show(); }; void MyClass::Show...