この記事では
プログラミング学習サービスpaizaラーニングの
スキルチェックレベルアップ問題集をわかりやすく解説します!
プログラミング言語はpythonです。
今回はCランク相当の以下の問題を解説します。
ぜひご参考ください!
またpaizaの各ランクの攻略法は
こちらで詳しく紹介しているので、ぜひご参考ください!
検索履歴 (paizaランク C 相当)の解答と解説
今回の問題は「 検索履歴(paizaランク C 相当)」です。
問題はこちらからご確認ください。
この問題を解くのに必要な知識は8つです。
- 入力を受け取る
- str型からint型に変換
- 改行区切りの入力を受け取る
- リストの要素を追加
- リスト内に同じ要素がないか条件を課す
- リストの要素を削除
- リストを逆順に並び替え
- リストの各要素を改行区切りで出力
この記事では、上記の8つの中で
- リスト内に同じ要素がないかで条件を課す
- リストを逆順に並び替え
- リストの各要素を改行区切りで出力
の3つを詳しく解説します。
残りの
については、以下の記事をご参考ください!
リスト内に同じ要素がないかで条件を課す
まずは「リスト内に同じ要素がないかで条件を課す」です。
今回の問題は、最初に入力される検索ワードの数が入力され
その後に改行区切りで検索ワードが入力されます。
そのためまずは変数とリストを使って入力を受け取ります。
# 検索ワードの数の入力を受け取る
num = int(input())
# 検索ワードを受け取るリスト
words = []
# 検索ワードの入力を受け取り、リストに格納
for _ in range(num):
input_word = input()
words.append(input_word)
for文については、こちらをご参考ください!
次に検索ワードの入力を受け取る際に
履歴中の同じ検索ワードを削除し
履歴の先頭に新たにそのワードを追加しなければなりません。
そのため「リスト内に同じ要素がないか」で条件を課して
同じ要素がある場合、removeメソッドを使ってその要素を削除します。
# 検索ワードの入力を受け取り、リストに格納
for _ in range(num):
input_word = input()
# リスト内に同じ要素がある場合
if word in words:
# その要素を削除
words.remove(word)
words.append(input_word)
if文とリストについては、こちらをご参考ください!
リストを逆順に並び替え
次は「リストを逆順に並び替え」です。
今回の問題では、履歴中の検索ワードを新しい順に出力します。
そのためリストの要素を逆順に並び替える必要があるので
reversed関数を使います。
reversed((リスト))
# リストの要素を逆順に並び替える
reversed_words = reversed(words)
リストの各要素を改行区切りで出力
最後は「リストの各要素を改行区切りで出力」です。
今回の問題では、履歴中の検索ワードを改行区切りで出力します。
そのためfor文を使って、リストの各要素を出力します。
# リストの要素を逆順に並び替える
reversed_words = reversed(words)
# リストの要素を改行区切りで出力
for word in reversed_words:
print(word)
また、新たに変数を置かずに要素を逆順に並び替えるとよりシンプルです。
# リストの要素を逆順に並び替え、改行区切りで出力
for word in reversed(words):
print(word)
for文については、こちらをご参考ください!
検索履歴 (paizaランク C 相当)の解答
まとめると「検索履歴 (paizaランク C 相当)」の解答は以下です。
# 検索ワードの数の入力を受け取る
num = int(input())
# 検索ワードを受け取るリスト
words = []
# 検索ワードの入力を受け取り、リストに格納
for _ in range(num):
input_word = input()
words.append(input_word)
# リストの要素を逆順に並び替え、改行区切りで出力
for word in reversed(words):
print(word)
この問題では、「for文とif文の組み合わせ」が必要になりました。
しかしここまで解説したように、処理を分割しそれぞれを一つ一つ見ていくと
基本通りの内容で特に難しいものは無かったかと思います。
ぜひ他の問題も処理の流れをイメージし
そして分割した上で問題に取り組んでいきましょう!
まとめ
今回はpaizaのスキルチェック過去問題の中で
- 検索履歴(paizaランク C 相当)
の解答と解説を紹介しました。
Dランクの問題に比べて、コードが複雑になります。
そのためコードを書き始める前に
頭の中で処理の流れをイメージをしてから書いていくのがおすすめです!
また他のレベルアップ問題集の問題についての解説も、ぜひご参考ください!