C言語の構造体にてバブルソートが上手くいきません‥
初めて質問致します。
以下は、構造体で、身長順にバブルソートを行うソース文ですが、
結果表示が、最下部に示したように、
5つのレコードのうち1つが消えてしまい、
残った4つのレコードのうちの1つが重複されて表示されてしまいます。
これが、なかなか解決できません‥。
既に結構調べており、また、早く解決できないといけないこともあり、
すみませんが、回答の形式でお願いできますと大変幸いです。
何卒よろしくお願い致します。
#include<stdio.h>
#include<string.h>
typedef struct kojin {
char name[21];
int length;
int weight;
}KOJIN;
int main(void)
{
int i, c, j;
char buf[4];
KOJIN data[10];
KOJIN *d;
printf(
No.4ベストアンサー
- 回答日時:
>for(i=0;i<10;i++) {
>d = &data[i];
最終的には、 dには &data[9] 、つまり、data[9]へのポインタが入っているわけです。
そして、そのまま
>*d= data[i];
>data[i]= data[j];
>data[j]= *d;
を実行したら
*dはdata[9]になりますから
data[9]= data[i];
data[i]= data[j];
data[j]= data[9];
と同じ事、となります。
一応、data[i]とdata[j]との入れ替えにはなりますが、同時にdata[i]がdata[9]へコピーされてしまい、もとあったdata[9]の内容が失われます。
最終的に、最後の入れ替えが発生したときのdata[i]と同じ値がdata[9]に入っているとこになります。
対策は、この KOJIN *d を使わないことです
KOJIN temp ;
としておいて
temp= data[i];
data[i]= data[j];
data[j]= temp;
とします。
ところで、これ、バブルソートじゃないですよ。
単純ソートというアルゴリズムになってます。
アルゴリズムの参考書等をもう一度よく確認してください。
言われたとおりにして、無事解決することができました。
本当にありがとうございました。
問題となったソース文は、temp等にすることで、上手くいき、
ポインタ(*d)ではダメということでしたね‥。
よい勉強をさせていただきました。
他の皆様も、ご意見をいただきありがとうございました。
No.3
- 回答日時:
そういう表示結果を得たとき、何を入力したのでしょうか?
>5つのレコードのうち1つが消えてしまい、
>残った4つのレコードのうちの1つが重複されて表示されてしまいます。
という状況が伝わっていません。
No.2
- 回答日時:
これで 5個のデータ「だけ」入力できるの? なにがなんでも 10個入力しないとダメな気がするんだけど....
さておき, データの入力が終わったときの d の値を調べてください.
あとおまけだけど, 「身長」は length じゃなくて height ではないかな.
No.1
- 回答日時:
お願い致します。
と言われても・・・・・
尻切れトンボじゃ、わかりません。
この回答への補足
大変申し訳ありません‥
携帯から投稿したのですが、まさかこんなことになっていたとは‥
改めて、ソース全文を載せます。
何卒よろしくお願い致します。
#include<stdio.h>
#include<string.h>
typedef struct kojin {
char name[21];
int length;
int weight;
}KOJIN;
int main(void)
{
int i, c, j;
char buf[4];
KOJIN data[10];
KOJIN *d;
printf("\n");
for(i=0;i<10;i++) {
d = &data[i];
printf("%d人目のデータ入力-------------\n",i+1);
printf("名前を入力>");
fgets(d->name,21,stdin);
if (strchr(d->name, '\n') != NULL) {
strtok(d->name,"\n");
} else {
while((c = getchar() != '\n') && (c != EOF));
}
printf("身長を入力>");
fgets(buf,sizeof buf,stdin);
if (strchr(buf, '\n') != NULL) {
strtok(buf,"\n");
} else {
while((c = getchar() != '\n') && (c != EOF));
}
sscanf(buf,"%d",&d->length);
printf("体重を入力>");
fgets(buf,sizeof buf,stdin);
if (strchr(buf, '\n') != NULL) {
strtok(buf,"\n");
} else {
while((c = getchar() != '\n') && (c != EOF));
}
sscanf(buf,"%d",&d->weight);
}
for (i=0 ; i<10 ; i++) {
for (j=9 ; j>i ; j--) {
if ( data[i].length > data[j].length ) {
*d= data[i];
data[i]= data[j];
data[j]= *d;
}
}
}
printf("\n");
for(i=0;i<10;i++) {
d = &data[i];
printf("レコード=%d %-20s 身長=%dcm 体重=%dkg\n"
,i+1,d->name,d->length,d->weight);
}
return 0;
}
----------------------<表示結果>----------------------
レコード=1 g h 身長=164cm 体重=57kg
レコード=2 e e 身長=169cm 体重=66kg
レコード=3 s y 身長=172cm 体重=65kg
レコード=4 a a 身長=176cm 体重=70kg
レコード=5 a a 身長=176cm 体重=70kg
------------------------------------------------------
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語初心者 構造体 課題について 1 2023/03/10 19:30
- C言語・C++・C# C言語初心者 構造体 課題について 2 2023/03/10 19:48
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- C言語・C++・C# バイナリファイルをコピーするのにかかる時間を測りたいのですが実行するとFatel error:gli 2 2022/11/03 01:10
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# C言語(構造体) 3 2022/07/05 20:08
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# カードシャッフルのブログラムを使ってc言語でブラックジャックをしたい 2 2022/04/12 15:13
- C言語・C++・C# c言語でユーザ関数を利用して入力された文字列を反転させるプログラムを作りたいです。 3 2023/01/29 19:47
このQ&Aを見た人はこんなQ&Aも見ています
-
見学に行くとしたら【天国】と【地獄】どっち?
みなさんは、一度だけ見学に行けるとしたら【天国】と【地獄】どちらに行きたいですか? 理由も聞きたいです。
-
スマホに会話を聞かれているな!?と思ったことありますか?
スマートフォンで検索はしてないのに、友達と話していた製品の広告が直後に出てきたりすることってありませんか? こんな感じでスマホに会話を聞かれているかも!?と思ったエピソードってありますか?
-
【お題】ヒーローの謝罪会見
【大喜利】 怪人の侵略に気づくのが遅れ、それを防げなかった戦隊ヒーローの謝罪会見で出た発言
-
プリン+醤油=ウニみたいな組み合わせメニューを教えて!
プリンと醤油を一緒に食べると「ウニ」の味がする! というような意外な組み合わせから、新しい味になる食べ物って色々ありますよね。 あなたがこれまでに試した「組み合わせメニュー」を教えてください。
-
お風呂の温度、何℃にしてますか?
みなさん、家のお風呂って何℃で入ってますか? ぬるめのお湯にゆったり…という方もいれば、熱いのが好き!という方もいるかと思います。 我が家は平均的(?)な42℃設定なのですが、みなさんのご家庭では何℃に設定していますか?
-
ファイルから読み込んだデータを構造体に格納できますか?
C言語・C++・C#
-
構造体の勉強中です 合計点の高い順に並べ替えがわかりません
C言語・C++・C#
-
fgetsなどのときのstdinのバッファを消すには?
C言語・C++・C#
-
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~12/2】 国民的アニメ『サザエさん』が打ち切りになった理由を教えてください
- ・ちょっと先の未来クイズ第5問
- ・【お題】ヒーローの謝罪会見
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBA:日付データの変換...
-
printfの%eで指数部分の桁数を...
-
(C言語・配列)date[i]の分散...
-
c言語 Bitについて
-
マクロ登録したピボットが重い...
-
sort関数でひらがなとカタカナ...
-
VisualBasicでレジストリキーの...
-
C言語でのLinuxとwindows共通の...
-
データの値の近いものをグルー...
-
PINVOKEで構造体配列をマーシャ...
-
stable diffusionのエラー
-
linuxのシェルでファイル名に先...
-
matlabのソースコードをpython...
-
エクセルシート名の制限を変更...
-
UTF-8で5~6バイトになる文字コ...
-
10Mバイトて文字数に すると何...
-
.netで、ibm漢字で書かれたテキ...
-
Excel VBA メール作成について ...
-
Excel 1セル当りの文字数が2...
-
UCS-2の一覧表が欲しい
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
printfの%eで指数部分の桁数を...
-
stable diffusionのエラー
-
ポインター引数の関数でコンパ...
-
エクセルVBA:日付データの変換...
-
C#でのswitch文
-
CreateProcessでの環境変数の設...
-
RegQueryValueExでの2バイト文字
-
'dataType' 引数を Null にする...
-
【Excel VBA】10進数を2進数に...
-
C++ multipart/form-data f
-
matlabのソースコードをpython...
-
Cのプログラムがどうしても動き...
-
テキストファイルの結合について
-
int型(2バイト)データの分割
-
Excel VBA グラフ作成のとき...
-
C言語 構造体の名前欄?を小文...
-
CSVファイルの行と列のセルって...
-
C++/CLIのオブジェクト型配列
-
C言語 ファイル内のデータと入...
-
C言語についてです! 同じ年の...
おすすめ情報