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

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

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

Whileは多くの言語で使われるコントロール構造であり、特定の条件が満たされる限り一連の命令を繰り返し実行します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

ソート

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

Python

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

Q&A

解決済

3回答

2662閲覧

pythonでのバブルソートのアルゴリズム

A_.

総合スコア5

while

Whileは多くの言語で使われるコントロール構造であり、特定の条件が満たされる限り一連の命令を繰り返し実行します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

ソート

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

Python

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

0グッド

1クリップ

投稿2021/07/13 11:10

編集2021/07/14 03:00

pythonで下のようなプログラムを書きたいです。
whileを使い書きたいのですが、どうしても分からないのでぜひ教えていただけませんか。

ヒントだけでもお願いします

python

1a = [98, 54, 21, 66, 30, 16] 2n = len(a) 3 4i = 0 5 6while i < n - 1: 7 j = n - 1 8 while j > i: 9 if n[j] < n[j-1]: 10 n[j], n[j-1] = n[j-1],n[j] 11 12print(a)

書いてみましたが、エラーで動きません。教えてください。

実行すると、
if n[j] < n[j-1]:
TypeError: 'int' object is not subscriptable
というエラーが出ました。

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

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

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

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

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

episteme

2021/07/13 11:36

どんなエラーが出たかくらいは書こうよ。
A_.

2021/07/13 11:37

'int' object is not subscriptable です。
episteme

2021/07/13 11:41

それが"どこ"で出たのかも。 # 質問は編集できます。追記してください
guest

回答3

0

if n[j] < n[j-1]:
TypeError: 'int' object is not subscriptable

ヒントの絵をよーく見よう。
a[j] > a[j+1] ならば入れ替え」

と書いてある。

あなたのやっていることは
n[j] < n[j-1] ならば入れ替え」
だ。nはlist(配列)ではない。

もうひとつ(ふたつ?)、ヒントの絵をよーく見よう。
j = j + 1, i = i + 1 と書いてある。
あなたのコードにはそれがない。

投稿2021/07/13 11:48

編集2021/07/13 20:30
episteme

総合スコア16614

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

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

A_.

2021/07/13 14:15

a[j] > a[j-1] のところ a[j] > a[j+1] なのでしょうか?
episteme

2021/07/13 14:53

その根拠は?
A_.

2021/07/13 15:43

昇順に並び替えるので、右より左の方が大きい時、順番を入れ替えるのではないかと思いました。
episteme

2021/07/13 20:31 編集

あ...そうね。 ごめん僕のマチガイ。(修正します) てかなんであなたのコードはヒントどおりに書いてないんだ?
A_.

2021/07/14 02:59

よく見ていませんでした。
guest

0

ベストアンサー

繰返しのカウンタを変数iであらわす

i = 1~n-1まで繰り返せばよい

Python

1i = 1 2while i <= n - 1: # i < n でも同じ 3 内側のループ 4 i = i + 1

a[0]からa[4]を表す

カウンタに変数jを使
うと、1回点目は
j=0~4

「1回点目」は「1回転目」の間違いでしょう。内側のループは、

Python

1 j = 0 2 while j < n - i: 3 比較と交換 4 j = j + 1

a[j] > a[j+1]ならば入れ替え

比較と交換は

Python

1 if a[j] > a[j+1]: 2 a[j], a[j+1] = a[j+1], a[j]

書いてある通りにコーディングするとこうなりませんか?

投稿2021/07/13 21:59

kazuma-s

総合スコア8224

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

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

A_.

2021/07/14 02:59

ありがとうございます
guest

0

エラーメッセージが出たならエラーメッセージぐらい読みましょう

エラーメッセージは怒声でも罵倒でも罵声でもハラスメントでもなく、
インタプリタ等からのメッセージです。

つまり、今の状況は『相手の話を聞かずに逆ギレしている人』です。

そんな人はコミュニケーションなんて取れませんよね。

まずはエラーメッセージぐらい読みましょう。

プログラミングは『書いて終わり』…ではありません。

デバッグやテストも含みます。

デバッグまではできて当然です。


[追記1]

ヒント: ここ

投稿2021/07/13 11:34

編集2021/07/13 12:07
BeatStar

総合スコア4958

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問