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

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

詳細はこちら
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

1回答

1169閲覧

atcoderの問題(ABC136_C)が解けません。

Taurus423

総合スコア13

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/11/07 16:32

例の入力に対しての出力は合っていましたが、testcaseが2つほど通りません。
お力添えいただけると幸いです。
https://atcoder.jp/contests/abc136/tasks/abc136_c

python

1N = int(input()) 2H = list(map(int,input().split())) 3for i in range(N-1): 4 if (H[i+1]-H[i]<=-1): 5 H[i] -= 1 6for i in range(N-1): 7 if (H[i+1]-H[i]<=-1): 8 print('No') 9 exit() 10print('Yes')

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

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

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

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

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

guest

回答1

0

(H[i+1]-H[i]<=-1)

この条件式すごくわかりにくくないですか?
H[i] >= H[i+1] + 1
とかのほうがいいと思いますよ.条件式はなるべく簡潔に,見やすく,できれば負数の比較とかせずに行うのがおすすめです.

本題です.
この問題は「単調非減少にする」というものなので,左は小さくできるだけ小さくするべきですよね?ですので,H[i] == H[i+1]でもH[i]は全然-1できます.というかするべきです.なるべく減算していかないと,正しい結果が得られません.「もっと減算していれば単調非減少にできた」みたいなケースが出てきます.つまり減算は「できるならする」が原則になります.
ここで重要になる,「減算できない場合」です.それはずばり「減算すると左より小さくなる場合」です.つまりH[i-1] > H[i]-1です.逆にH[i-1] < H[i]であるなら減算できます.
あと減算した時点でA[i]より左は変わらないし,A[i+1]は小さくなりこそすれ大きくなることはないので,直後にNoの判定をするべきです.
というわけで自分がACしたのは次のコードです.for文中ではH[i-1]を参照するのでH[0]は先に処理しておきます.

python

1def main(): 2 N = int(input()) 3 H = [int(x) for x in input().split()] 4 H[0] -= 1 5 for i in range(1, N - 1): 6 if H[i-1] < H[i]: 7 H[i] -= 1 8 if H[i] > H[i+1]: 9 print('No') 10 break 11 else: 12 print('Yes') 13 return 14 15main()

投稿2019/11/07 17:58

編集2019/11/07 18:00
kairi003

総合スコア1332

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

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

Taurus423

2019/11/11 11:40

回答いただきありがとうございます。 H[i] == H[i+1]のとき減算するとなると12113のときなどで通らないと思うのですが... 以下のように書き換えてみたのですがまだ通らないようです。 引き続き回答頂けると幸いです。 N = int(input()) H = list(map(int,input().split())) for i in range(1,N): if H[i-1]>H[i]: H[i-1] -= 1 for i in range(1,N): if H[i-1]>H[i]: print('No') exit() print('Yes')
kairi003

2019/11/11 11:58

減算するかどうかは、次の値ではなく前の値で評価するべきです。 H[i-1] -= 1 だと結局iとi+1で評価してるのと変わりません。 H[i] -= 1 です。 またH[0]は必ず減算できます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問