結果
問題 | No.345 最小チワワ問題 |
ユーザー | y32M-71693993 |
提出日時 | 2016-02-26 22:52:24 |
言語 | C++11 (gcc 11.4.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 4,786 bytes |
コンパイル時間 | 1,603 ms |
コンパイル使用メモリ | 157,616 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-09-25 11:25:36 |
合計ジャッジ時間 | 2,189 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
6,816 KB |
testcase_01 | AC | 1 ms
6,944 KB |
testcase_02 | AC | 1 ms
6,940 KB |
testcase_03 | AC | 2 ms
6,940 KB |
testcase_04 | AC | 1 ms
6,944 KB |
testcase_05 | AC | 2 ms
6,948 KB |
testcase_06 | AC | 2 ms
6,940 KB |
testcase_07 | AC | 1 ms
6,940 KB |
testcase_08 | AC | 1 ms
6,944 KB |
testcase_09 | AC | 1 ms
6,940 KB |
testcase_10 | AC | 2 ms
6,944 KB |
testcase_11 | AC | 2 ms
6,940 KB |
testcase_12 | AC | 1 ms
6,940 KB |
testcase_13 | AC | 2 ms
6,940 KB |
testcase_14 | AC | 2 ms
6,940 KB |
testcase_15 | AC | 2 ms
6,944 KB |
testcase_16 | AC | 1 ms
6,944 KB |
testcase_17 | AC | 2 ms
6,940 KB |
testcase_18 | AC | 2 ms
6,944 KB |
testcase_19 | AC | 2 ms
6,944 KB |
testcase_20 | AC | 2 ms
6,940 KB |
testcase_21 | AC | 1 ms
6,940 KB |
testcase_22 | AC | 2 ms
6,944 KB |
testcase_23 | AC | 2 ms
6,940 KB |
testcase_24 | AC | 2 ms
6,944 KB |
testcase_25 | AC | 1 ms
6,940 KB |
testcase_26 | AC | 2 ms
6,940 KB |
testcase_27 | AC | 2 ms
6,940 KB |
testcase_28 | AC | 2 ms
6,940 KB |
testcase_29 | AC | 1 ms
6,940 KB |
testcase_30 | AC | 1 ms
6,940 KB |
testcase_31 | AC | 2 ms
6,944 KB |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:62:27: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 62 | #define SCANF_STR(a) scanf("%s", a); | ~~~~~^~~~~~~~~ main.cpp:8:9: note: in expansion of macro ‘SCANF_STR’ 8 | MACRO(A0, ##__VA_ARGS__) | ^~~~~ main.cpp:5:69: note: in expansion of macro ‘EXPAND_01’ 5 | #define GET_MACRO_09(A0, A1, A2, A3, A4, A5, A6, A7, A8, NAME, ...) NAME | ^~~~ main.cpp:40:28: note: in expansion of macro ‘EXPAND_ARG_0’ 40 | #define EXPAND(MACRO, ...) EXPAND_ARG_0(MACRO, __VA_ARGS__) | ^~~~~~~~~~~~ main.cpp:64:17: note: in expansion of macro ‘EXPAND’ 64 | #define SR(...) EXPAND(SCANF_STR, __VA_ARGS__) | ^~~~~~ main.cpp:65:38: note: in expansion of macro ‘SR’ 65 | #define S(N, ...) SD(N, __VA_ARGS__) SR(__VA_ARGS__) | ^~ main.cpp:111:9: note: in expansion of macro ‘S’ 111 | S(120, s); | ^
ソースコード
#include <bits/stdc++.h> using namespace std; // Macro Tools ///////////////////////////////////////////////////////////////// #define GET_MACRO_09(A0, A1, A2, A3, A4, A5, A6, A7, A8, NAME, ...) NAME #define EXPAND_01(MACRO, A0, ...) \ MACRO(A0, ##__VA_ARGS__) #define EXPAND_02(MACRO, A0, A1, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) #define EXPAND_03(MACRO, A0, A1, A2, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) #define EXPAND_04(MACRO, A0, A1, A2, A3, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) \ MACRO(A3, ##__VA_ARGS__) #define EXPAND_05(MACRO, A0, A1, A2, A3, A4, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) \ MACRO(A3, ##__VA_ARGS__) MACRO(A4, ##__VA_ARGS__) #define EXPAND_06(MACRO, A0, A1, A2, A3, A4, A5, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) \ MACRO(A3, ##__VA_ARGS__) MACRO(A4, ##__VA_ARGS__) MACRO(A5, ##__VA_ARGS__) #define EXPAND_07(MACRO, A0, A1, A2, A3, A4, A5, A6, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) \ MACRO(A3, ##__VA_ARGS__) MACRO(A4, ##__VA_ARGS__) MACRO(A5, ##__VA_ARGS__) \ MACRO(A6, ##__VA_ARGS__) #define EXPAND_08(MACRO, A0, A1, A2, A3, A4, A5, A6, A7, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) \ MACRO(A3, ##__VA_ARGS__) MACRO(A4, ##__VA_ARGS__) MACRO(A5, ##__VA_ARGS__) \ MACRO(A6, ##__VA_ARGS__) MACRO(A7, ##__VA_ARGS__) #define EXPAND_09(MACRO, A0, A1, A2, A3, A4, A5, A6, A7, A8, ...) \ MACRO(A0, ##__VA_ARGS__) MACRO(A1, ##__VA_ARGS__) MACRO(A2, ##__VA_ARGS__) \ MACRO(A3, ##__VA_ARGS__) MACRO(A4, ##__VA_ARGS__) MACRO(A5, ##__VA_ARGS__) \ MACRO(A6, ##__VA_ARGS__) MACRO(A7, ##__VA_ARGS__) MACRO(A8, ##__VA_ARGS__) #define GET_EXPAND(...) GET_MACRO_09(__VA_ARGS__, EXPAND_09, EXPAND_08, \ EXPAND_07, EXPAND_06, EXPAND_05, EXPAND_04, EXPAND_03, EXPAND_02, EXPAND_01) #define EXPAND_ARG_0(MACRO, ...) GET_EXPAND(__VA_ARGS__)(MACRO, __VA_ARGS__) #define EXPAND_ARG_1(MACRO, A0, ...) GET_EXPAND(__VA_ARGS__)(MACRO, __VA_ARGS__, A0) #define EXPAND(MACRO, ...) EXPAND_ARG_0(MACRO, __VA_ARGS__) #define Q(x) #x #define QUOTE(x) Q(x) // Input /////////////////////////////////////////////////////////////////////// #define SCANF_INT(a) scanf("%d", &(a)); #define ID(...) int __VA_ARGS__; #define IR(...) EXPAND(SCANF_INT, __VA_ARGS__) #define I(...) ID(__VA_ARGS__) IR(__VA_ARGS__) // #define DEFINE_INT_ARRAY(a, n) int a[n]; // #define INT_ITH_ARRAY(a, i) a[i] // #define IAD(N, ...) EXPAND_ARG_1(DEFINE_INT_ARRAY, N, __VA_ARGS__) // #define IAR(N, ...) REP(array_reader_i, N){ \ #define SCANF_LL(a) scanf("%I64d", &(a)); #define LD(...) ll __VA_ARGS__; #define LR(...) EXPAND(SCANF_LL, __VA_ARGS__) #define L(...) LD(__VA_ARGS__) LR(__VA_ARGS__) #define DEFINE_STR(a, n) char a[n]; #define SCANF_STR(a) scanf("%s", a); #define SD(N, ...) EXPAND_ARG_1(DEFINE_STR, N, __VA_ARGS__) #define SR(...) EXPAND(SCANF_STR, __VA_ARGS__) #define S(N, ...) SD(N, __VA_ARGS__) SR(__VA_ARGS__) // Output ////////////////////////////////////////////////////////////////////// #define LN printf("\n"); #define IP(a, ...) printf("%d", a); // Types /////////////////////////////////////////////////////////////////////// typedef long long ll; typedef pair<int, int> pii; typedef pair<ll, ll> pll; typedef set<int> si; typedef set<ll, ll> sll; typedef vector<int> vi; typedef vector<ll> vll; typedef list<int> li; typedef list<ll> lll; typedef map<int, int> mii; typedef map<int, ll> mil; typedef map<ll, int> mli; typedef map<ll, ll> mll; // Loop & Iteration //////////////////////////////////////////////////////////// #define FOR(i, a, b) for(int i = (a), loop_end_##i=(b); i < (loop_end_##i); i++) #define REP(i, n) FOR(i, 0, n) #define EACH(i,c) for(auto i=(c).begin(); i!=(c).end(); ++i) #define EXIST(s,e) ((s).find(e)!=(s).end()) #define ALL(a) (a).begin(), (a).end() #define SORT(a) sort(ALL(a)) #define SORTA(a, n) sort(a, a+n); #define PB push_back #define itr iterator // Range /////////////////////////////////////////////////////////////////////// #define IN(x, a, b) (a<=x && x<b) int dx[8] = { 1, 0, 0,-1, 1, 1,-1,-1}; int dy[8] = { 0,-1, 1, 0,-1, 1,-1, 1}; #define LARGER(a, b) a=max(a, b) #define SMALLER(a, b) a=min(a, b) //////////////////////////////////////////////////////////////////////////////// int main(){ S(120, s); int n = strlen(s); int ans = INT_MAX; REP(i, n){ if(s[i]=='c'){ int wcnt = 0; int bord = 0; FOR(j, i, n){ if(s[j]=='w'){ wcnt++; } if(wcnt==2){ bord = j + 1; break; } } if(wcnt==2){ SMALLER(ans, bord - i); } } } printf("%d\n", ans==INT_MAX?-1:ans); }