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

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

新規登録して質問してみよう
ただいま回答率
85.48%
ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

Python

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

Q&A

5回答

1087閲覧

2つのソート済みの整数列を併合する

apaka

総合スコア0

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

Python

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

0グッド

0クリップ

投稿2021/11/22 11:59

前提・実現したいこと

2つのソート済みの整数列を併合させる問題です。
答えは

[7,8,15,20,24,25,26,30,32]

としたいのですが、どこが違うのかがわかりません。

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

8 15 20 26 30 32
7 24 25
[7, 24, 25]

該当のソースコード

python

a=[]
b=[]
a.append([int(i) for i in input().split()])
b.append([int(i) for i in input().split()])
d=[]
i=0
j=0

while i<len(a) and j<len(b):
if a[i]<=b[j]:
d.append(a[i])
i+=1

else: d.append(b[j]) j+=1

print(*d)

試したこと

補足情報(FW/ツールのバージョンなど)

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

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

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

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

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

takasima20

2021/11/22 12:43

とりあえず a b は append じゃなくて、直接代入しましょう。
guest

回答5

0

他の方が回答されている通りですね。
参考までに地道なやり方だとこんなかんじでしょか。

python

1a = [int(i) for i in input().split()] 2b = [int(i) for i in input().split()] 3 4d = [] 5i = 0 6j = 0 7while i<len(a) and j<len(b): 8 if a[i]<=b[j]: 9 d.append(a[i]) 10 i += 1 11 else: 12 d.append(b[j]) 13 j += 1 14while i<len(a): 15 d.append(a[i]) 16 i += 1 17while j<len(b): 18 d.append(b[j]) 19 j += 1 20 21print(*d)

投稿2021/11/22 12:55

takasima20

総合スコア7458

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

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

apaka

2021/11/22 13:21

みなさんの言う通りでした!ありがとうございました!
guest

0

残りを加えましょう(スライスにすることで範囲外の場合は空リストが返ります)。

python

1a = [8, 15, 20, 26, 30, 32] 2b = [7, 24, 25] 3 4d=[] 5i=0 6j=0 7 8while i < len(a) and j < len(b): 9 if a[i] <= b[j]: 10 d.append(a[i]) 11 i += 1 12 else: 13 d.append(b[j]) 14 j += 1 15 16d += a[i:] + b[j:] 17 18print(*d) 19 20 21# 227 8 15 20 24 25 26 30 32

投稿2021/11/22 12:53

編集2021/11/22 13:03
melian

総合スコア19703

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

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

apaka

2021/11/22 13:21

わざわざありがとうございました!
guest

0

処理に「片方のリストがなくなったとき」の考慮が抜けています。

片方がなくなれば、残りをすべて結果リストに入れる必要がありますね。

投稿2021/11/22 12:44

TakaiY

総合スコア12743

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

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

apaka

2021/11/22 13:22

おっしゃる通りでした。勉強になりました。ありがとうございました!
guest

0

現状のプログラムでは、a, bどちらかの要素を全て処理してしまったところでwhileループを抜けてしまいます。
ループの後に残ってしまった要素を追加する処理が必要です。
たとえば、以下のような感じで。

python

1a = [8, 15, 20, 26, 30, 32] 2b = [7, 24, 25] 3 4d = [] 5i = 0 6j = 0 7 8while i < len(a) and j < len(b): 9 if a[i] <= b[j]: 10 d.append(a[i]) 11 i += 1 12 else: 13 d.append(b[j]) 14 j += 1 15 16print(*d) 17 18print('=' * 20) 19print('aの残り:', a[i:]) 20print('bの残り:', b[j:]) 21d.extend(a[i:] if i < len(a) else b[j:]) 22print(*d)

投稿2021/11/22 12:38

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

適当にインデントを付けて実行してみると、

python

1>>> print(*d) 27 8 15 20 24 25

となりました。

この結果が間違っているのは、whileの判定方法が間違っていることです。
ただし、whileの判定方法を変更するだけではだめで、その中のifの判定もかなり変更する必要があります。

投稿2021/11/22 12:15

ppaul

総合スコア24666

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

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

apaka

2021/11/22 13:22

無事にできました。ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問