質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.46%
C++

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

Q&A

解決済

1回答

939閲覧

AtCoderのABC004「C-入れ替え」で実行時間超過してしまう

smile_20200722

総合スコア11

C++

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

0グッド

0クリップ

投稿2021/04/02 03:48

前提・実現したいこと

AtCoder ABC004 「C-入れ替え」の通過です。

問題文をうまく貼り付けることができないので、お手数ですが以下のリンクより問題を確認していただけると助かります。

https://atcoder.jp/contests/abc004/tasks/abc004_3

以下に自分が書いたコードを載せています。
どうぞよろしくお願いいたします。

発生している問題・エラーメッセージ

いくつかのテストケースで実行時間が超過してしまい、通過できることができません。

該当のソースコード

c++

1#include <bits/stdc++.h> 2using namespace std; 3 4int main() { 5 char cards[7] = {'0', '1', '2', '3', '4', '5', '6'}; 6 int n; 7 cin >> n; 8 for(int i = 0; i <= n - 1; i++) { 9 char tmp = cards[(i % 5) + 1]; 10 cards[(i % 5) + 1] = cards[(i % 5) + 2]; 11 cards[(i % 5) + 2] = tmp; 12 } 13 for(int i = 1; i < 7; i++) { 14 cout << cards[i]; 15 } 16 cout << endl; 17 18 return 0; 19}

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

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

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

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

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

guest

回答1

0

ベストアンサー

この問題は愚直に解くとタイムアウトするようにできています。
問題の操作をするとある回数で元の並びに戻ります。
なので、Nをある回数で割った余りの数だけ操作すればよいです。

なお、AtCoderには解説がありますので(問題のページにもリンクがあります)
詰まったときにはまずはそれに目をとおしてみてください。

投稿2021/04/02 04:44

can110

総合スコア38278

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

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

smile_20200722

2021/04/02 08:37

can110さん、返信ありがとうございます。 無事に通過できました。 オフィシャルのページを見て、解説はないものだと思ってました。 スライドがあったことを知りませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問