作成日
2014/12/18最終更新
2017/03/25記事区分
一般公開構造体
#include <iostream>
using namespace std;
struct MyStruct {
char charval;
int intval;
};
void Show(MyStruct* obj) {
cout << obj->intval << endl;
}
int main() {
MyStruct objs[] = {
{'a', 97},
{'b', 98},
};
int size = sizeof objs / sizeof *objs;
for (int i = 0; i < size; ++i) {
cout << objs[i].charval << ": " << flush;
Show(&objs[i]);
}
return 0;
}
列挙体
#include <iostream>
using namespace std;
enum MyEnum {
VALUE_A,
VALUE_B,
VALUE_C // 最後の要素にカンマをつけるとエラーになるコンパイラが存在
};
MyEnum MyFunc(MyEnum me) {
return me;
}
int main() {
cout << MyFunc(VALUE_A) << endl; //=> 0
cout << MyFunc(VALUE_B) << endl; //=> 1
cout << MyFunc(VALUE_C) << endl; //=> 2
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>
- 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...
- Union-Find サンプル『プログラミングコンテストでのデータ構造』で紹介されている Union-Find 木で集合を表現すると、以下のクエリを高速に実行できます。集合一つが一つの木となるため、複数の集合がある場合は全体として森になります。 ある要素 a_i と a_j が同じ集合に属しているかどうかの判定 二つの集合を一つの集合にまとめる サンプル [POJ 1182](https://translat