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

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

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

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

ソート

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

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

Q&A

解決済

2回答

2205閲覧

直接選択法によるソートの様子とソートに必要な比較回数と交換回数を数える

Na_ma6565

総合スコア2

C

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

ソート

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

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

0グッド

0クリップ

投稿2021/06/22 14:15

前提・実現したいこと

C言語で直接選択法によるソートの様子とソートに必要な比較回数と交換回数を数えるプログラムを作成したいです。とりあえず、直接選択法によるソートはできたのですが、可視化するにはどのようにプログラムを組めばよいかわかりません。

該当のソースコード

#include <stdio.h> #define N 6 void main(void) { int a[]={80,41,35,90,40,20}; int min,s,t,i,j; for (i=0;i<N-1;i++){ min=a[i]; s=i; for (j=i+1;j<N;j++){ if (a[j]<min){ min=a[j]; s=j; } } t=a[i]; a[i]=a[s]; a[s]=t; } for (i=0;i<N;i++) printf("%d ",a[i]); printf("\n"); }

試したこと

int内の文字の定義を増やして、printfで出力しようとしたのですが上手くいきませんでした。

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

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

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

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

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

jimbe

2021/06/22 14:37

> ソートの様子とソートに必要な比較回数と交換回数 の表示を追加した結果どのような表示になるとお考えなのか、"具体的に"教えて頂けますか。
Na_ma6565

2021/06/22 14:41

80 41 35 90 40 20 20 41 35 90 40 80 20 35 41 90 40 80 20 35 40 90 41 80 20 35 40 41 90 80 20 35 40 41 80 90 比較回数:15,交換回数:5 このようになるのを想定しています。 よろしくお願いします。
jimbe

2021/06/22 14:50

順番に見ていきましょう。 まず、最初の6行が"ソートの様子"ということですね。 現状はその6行のうち最後の行(=ソート結果)だけが表示されているものと思います。 このソート結果を表示しているのはプログラムのどの行かはご理解されていますでしょうか。
Na_ma6565

2021/06/22 14:56

最後のprintf2つだと思います。
jimbe

2021/06/22 15:15

> 最後のprintf2つ では残念ながら正確では無いと思います。 一つ目の printf が個々の数値を表示していますので、その前の for 文も含めて > for (i=0;i<N;i++) > printf("%d ",a[i]); > printf("\n"); この3行で行っているとお考えになる方が良いかと思います。 ですので、この3行をコピーして、一回ずつ交換を行う for ループの必要な場所にペーストすれば、交換の様子を表示できるのではないでしょうか。 ただしここで注意が必要なのは、for ループで使用している変数です。 for ループの中に別の for ループを入れる場合、(特にコピペで編集していると)二つの for ループで使用している変数が同じになってしまって意図しない動作(=バグ)となる場合があります。 「int内の文字の定義を増やして」との表記は「変数を増やして」ということを見ましたが、変数の理解がどこまでされているのかに疑問が生じています。 この辺りを注意しながら"交換の様子"を入れてみては如何でしょうか。
Na_ma6565

2021/06/22 15:18

ありがとうございます。 一度考えてみます。
guest

回答2

0

ベストアンサー

C

1#include <stdio.h> 2 3#define N 6 4 5int comps; // 比較回数 6int swaps; // 交換回数 7 8// 比較関数 9int comp(int x, int y) { 10 ++comps; 11 return x < y; 12} 13 14// 交換関数 15void swap(int* px, int* py) { 16 ++swaps; 17 int tmp = *px; 18 *px = *py; 19 *py = tmp; 20} 21 22int main(void) { 23 int a[]={80,41,35,90,40,20}; 24 int min,s,t,i,j; 25 26 comps = 0; 27 swaps = 0; 28 29 for (i=0;i<N-1;i++) { 30 min=a[i]; 31 s=i; 32 for (j=i+1;j<N;j++){ 33 if ( comp(a[j], min) < 0 ) { // ここで比較 34 min=a[j]; 35 s=j; 36 } 37 } 38 swap(&a[i], &a[s]); // ここで交換 39 } 40 41 for (i=0;i<N;i++) 42 printf("%d ",a[i]); 43 printf("\n"); 44 45 printf("%d comps / %d swaps\n", comps, swaps); 46 return 0; 47}

投稿2021/06/23 05:55

episteme

総合スコア16614

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

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

Na_ma6565

2021/06/23 14:05

ありがとうございます。
guest

0

これ がコタエになってますか?

投稿2021/06/22 14:57

episteme

総合スコア16614

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

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

Na_ma6565

2021/06/22 15:02

参考にしてみようと思ったのですが、わかりませんでした。 すみません。
episteme

2021/06/22 21:53

比較と交換を関数化し、それぞれの中で勘定してるだけなんですけど...
episteme

2021/06/23 05:54

回答しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問