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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

ソート

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

Q&A

解決済

2回答

1216閲覧

バブルソートを実行したいけれど並べ替えが全くなされない

nagagutu

総合スコア1

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

ソート

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

0グッド

0クリップ

投稿2021/05/22 08:33

前提・実現したいこと

配列をバブルソートで小さい順に並べ替えをしたい

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

並べ替えが全くなされていない

該当のソースコード

c言語

1#include <stdio.h> 2#include <stdlib.h> 3 4void swap(int *x, int *y); 5int main() 6{ 7 int a[7] = {17,9,18,3,12,8,15}; 8 int i,j,sorted; 9 int n = sizeof a /sizeof (a[0]) ; 10 j=n-1; 11 int k; 12 sorted = 1; 13 j = j-1; 14 for(i = 0;i<=j;i++) 15 { 16 if (a[i] > a[i+1]){ 17 swap(&a[i], &a[i+1]); 18 sorted = 0; 19 } 20 } 21 22 for (k = 0;k<n;k++) 23 { 24 printf("%d\n",a[k]); 25 } 26 27 printf("%d\n",n); 28 printf("%d\n",sorted); 29} 30 31void swap(int *x, int *y) 32{ 33 int *tmp; 34 35 tmp = x; 36 x = y; 37 y = tmp; 38}

試したこと

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

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

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

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

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

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

guest

回答2

0

ベストアンサー

C

1#include <stdio.h> 2#include <stdbool.h> 3 4void swap(int* x, int* y); 5 6int main() { 7 int a[7] = { 17,9,18,3,12,8,15 }; 8 int n = sizeof a / sizeof(a[0]); 9 bool sorted; 10 11 for (int i = n-1; i > 0; --i) { 12 sorted = true; 13 for ( int j = 0; j < i; ++j ) { 14 if (a[j] > a[j + 1]) { 15 swap(&a[j], &a[j + 1]); 16 sorted = false; 17 } 18 } 19 if ( sorted ) { 20 break; 21 } 22 } 23 24 for (int i = 0; i < n; ++i) { 25 printf("%d ", a[i]); 26 } 27 printf("\n"); 28 return 0; 29} 30 31void swap(int* x, int* y) { 32 int tmp = *x; 33 *x = *y; 34 *y = tmp; 35}

投稿2021/05/22 09:13

編集2021/05/22 09:15
episteme

総合スコア16614

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

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

nagagutu

2021/05/22 09:23

ありがとうございます。値を入れ替えるようにswap関数を変更したところ1回分の並べ替えができるようになりました!一回では最大値しかもとまらないので小さい順に並べ切るためにループをもうひとつ付け加えなければいけなかったですね、ありがとうございました!!
episteme

2021/05/22 09:25

loopを回るたびに最大値が末尾に押し出されるので、それを何度も(loop使って)繰り返す、と。
guest

0

swap関数の実装が問題です。このコードでは、ポインタ自体を入れ替えているだけで中身は変化していません。

投稿2021/05/22 08:44

maisumakun

総合スコア145184

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

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

episteme

2021/05/22 08:50

てか、「入れ替わってすらいない」よね♪
nagagutu

2021/05/22 09:08

ありがとうございます、数値を変更するようにswap関数を見直してみたところ、実行結果がいつまでも表示されない(実行が終わらない?)状態になってしまいました。どこかで抜けられないループになってしまっているのでしょうか? #include <stdio.h> #include <stdlib.h> void swap(int *x, int *y); int main() { int a[7] = {17,9,18,3,12,8,15}; int i,j,sorted; int n = sizeof a /sizeof (a[0]) ; j=n-1; int k; sorted = 1; j = j-1; do { for(i = 0;i<=j;i++) { if (a[i] > a[i+1]){ swap(&a[i], &a[i+1]); sorted = 0; } } }while(!sorted); for (k = 0;k<n;k++) { printf("%d\n",a[k]); } printf("%d\n",n); printf("%d\n",sorted); } void swap(int *x, int *y) { int tmp; tmp = *x; *x = *y; *y = tmp; }
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問