回答編集履歴
1
追記
answer
CHANGED
@@ -8,4 +8,30 @@
|
|
8
8
|
> }
|
9
9
|
|
10
10
|
ここが
|
11
|
-
題意に沿った判定を行っているように見えないのですが…?
|
11
|
+
題意に沿った判定を行っているように見えないのですが…?
|
12
|
+
どこが間違っているか? と問うには,
|
13
|
+
「何故この処理でやれる(と考える)のか?」という,あなたの考え(アルゴリズム)を説明する必要があるのではないでしょうか.
|
14
|
+
例えば,問題文に記載された条件全てを何の工夫もなく愚直に実装するとしたら,以下のようになると思いますが,このような愚直な状態と比較して「どのような工夫を行っているのか?」という話が.
|
15
|
+
```C++
|
16
|
+
//※入力がめんどくさいので代替
|
17
|
+
const std::string S = "RBRBGRBGGBBRRGBBRRRBGGBRBGBRBGBRBBBGBBB";
|
18
|
+
const int N = (int)S.size();
|
19
|
+
|
20
|
+
//愚直なカウント
|
21
|
+
unsigned int Ans = 0;
|
22
|
+
for( int i=0; i<N-2; ++i )
|
23
|
+
{
|
24
|
+
for( int j=i+1; j<N-1; ++j )
|
25
|
+
{
|
26
|
+
if( S[i] == S[j] )continue;
|
27
|
+
int dij = j - i;
|
28
|
+
for( int k=j+1; k<N; ++k )
|
29
|
+
{
|
30
|
+
if( k-j == dij )continue;
|
31
|
+
if( S[i]==S[k] || S[j]==S[k] )continue;
|
32
|
+
++Ans;
|
33
|
+
}
|
34
|
+
}
|
35
|
+
}
|
36
|
+
std::cout << Ans << std::endl;
|
37
|
+
```
|