🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

865閲覧

AtCoder Grand Contest 035 A - XOR Circle

encho

総合スコア182

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2020/12/16 23:37

編集2020/12/16 23:38

AtCoder Grand Contest 035 A - XOR Circle

AGC035A-XOR Circle

円環を考えるのではなく、vectorの先頭の前に末尾の値を、vectorの末尾の後に先頭の値を入れてその後に両隣の排他的論理和がその値に等しいかを調べてループを回しましたが、うまくはいかず、いくつかのテストケースで落ちてしまいました。

このコードのどこに問題があるのかお分かりの方にご教授いただきたいです。

c++

1#include <bits/stdc++.h> 2using namespace std; 3 4int main() { 5 long long N; 6 cin >> N; 7 vector<long long> A(N); 8 for(int i=0; i<N; i++) cin >> A[i]; 9 A.push_back(A[0]); 10 A.insert(A.begin(), A[N-1]); 11 12 bool flg = true; 13 for(int i=1; i<N+1; i++) { 14 if((A[i-1] ^ A[i+1]) != A[i]) flg = false; 15 } 16 cout << (flg ? "Yes" : "No") << endl; 17} 18

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

条件が成立するような帽子の被せ方が存在するならば Yes を、そうでなければ No を出力

という問題なのだから,
入力された順のパターンだけをチェックするのではなく,
相応に複数の(並べ替えた)パターンを試す必要があるのでは.

投稿2020/12/17 01:33

fana

総合スコア11985

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問