結果

問題 No.1053 ゲーミング棒
ユーザー kriii
提出日時 2020-05-15 21:29:45
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 14 ms / 2,000 ms
コード長 562 bytes
コンパイル時間 436 ms
コンパイル使用メモリ 51,328 KB
最終ジャッジ日時 2025-01-10 11:15:43
ジャッジサーバーID
(参考情報)
judge3 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 34
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:10:15: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   10 |         scanf ("%d", &N);
      |         ~~~~~~^~~~~~~~~~
main.cpp:12:23: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   12 |                 scanf ("%d", &A[i]);
      |                 ~~~~~~^~~~~~~~~~~~~

ソースコード

diff #

#include <stdio.h>
#include <algorithm>
#include <vector>
using namespace std;

int N, A[200200], C[100100];

int main()
{
	scanf ("%d", &N);
	for (int i = 0; i < N; i++){
		scanf ("%d", &A[i]);
		A[i + N] = A[i];
		C[A[i]]++;
	}

	int c = -1;
	for (int i = 1; i <= N; i++) if (C[i]) c++;
	for (int i = 1; i < N; i++) if (A[i] != A[i - 1]) c--;

	if (c == 0){
		puts("0");
		return 0;
	}
	for (int i = N; i < N * 2; i++){
		if (A[i - N] != A[i - N + 1]) c++;
		if (A[i] != A[i - 1]) c--;
		if (c == 0){
			puts("1");
			return 0;
		}
	}
	puts("-1");
	return 0;
}
0