結果
問題 | No.345 最小チワワ問題 |
ユーザー |
|
提出日時 | 2016-02-27 22:13:11 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 756 bytes |
コンパイル時間 | 586 ms |
コンパイル使用メモリ | 57,460 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-25 11:32:37 |
合計ジャッジ時間 | 1,480 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 29 |
ソースコード
#include <iostream> #include <algorithm> using namespace std; using i64 = long long; template<typename T> class Range{private:struct I{T x;T operator*(){return x;}bool operator!=(I& lhs){return x<lhs.x;}void operator++(){++x;}};I i,n; public:Range(T n):i({0}),n({n}){}Range(T i,T n):i({i}),n({n}){}I& begin(){return i;}I& end(){return n;}}; using range = Range<int>; const int inf = 2000; int main(void) { string s; cin >> s; int n = s.size(); int lag = inf; for(auto&& i : range(n)) { for(auto&& j : range(i+1, n)) { for(auto&& k : range(j+1, n)) { if(s[i] == 'c' && s[j] == 'w' && s[k] == 'w') { lag = min(lag, k-i+1); } } } } if(lag == inf) { lag = -1; } printf("%d\n", lag); return 0; }