以下のプログラムをnumber.txtというファイルから10個の整数を読み込み、ヒープソートでソートし、小さい順に表示できるように改良してください。
#include<stdio.h>
#define MAX 10
int check_heap(int a[],int n);
void insert(int val,int a[], int* N);
void swap(int* a,int* b);
int deletemin(int a[], int *n);
int main()
{
int heap[MAX];
int i,result;
int n=0;
int min;
insert(91,heap,&n);
insert(63,heap,&n);
insert(71,heap,&n);
insert(14,heap,&n);
insert(60,heap,&n);
insert(1,heap,&n);
insert(24,heap,&n);
insert(13,heap,&n);
insert(80,heap,&n);
insert(15,heap,&n);
for(i=0;i<n;i++)
{
printf("%d ",heap[i]);
}
printf("\n");
result=check_heap(heap,n);
if(result==1)
{
printf("ヒープ条件を満たしています.\n");
}
else {
printf("ヒープ条件を満たしていません\n");
}
min=deletemin(heap,&n);
printf("%d\n ",min);
for(i=0;i<n;i++)
{
printf("%d ",heap[i]);
}
printf("\n");
result=check_heap(heap,n);
if(result==1)
{
printf("ヒープ条件を満たしています.\n");
}
else {
printf("ヒープ条件を満たしていません\n");
}
return 0;
}
int check_heap(int a[],int n)
{
int i;
for(i = 0; i < n; i++) {
int left=2*i+1;
int right=2*i+2;
if(left >= n) {
continue;
}
if(a[left] < a[i]) {
return 0;
}
if(right >= n) {
continue;
}
if(a[right] < a[i]) {
return 0;
}
}
return 1;
}
//新しく値を挿入する関数
void insert(int val,int a[], int* N)
{
int i;
a[*N]=val;
for(i=*N;i!=0;i=(i-1)/2)
{
if(a[i]<a[(i-1)/2])//親が子より大きい場合
{
swap(&a[i],&a[(i-1)/2]);//関数呼びだし
}
}
(*N)++;
}
//値を入れ替える関数
void swap(int* a,int* b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
}
//ヒープの最小値を取り除く関数
int deletemin(int a[], int *N)
{
int min=a[0];
int i=1,j=i*2;
a[0]=a[--(*N)];//末尾の要素をルートに持ってくる
while(j<=(*N))
{
if(j+1<=(*N) && a[j-1]>a[j])
{
j++;
}
if(a[i-1]>a[j-1] )//親が子より大きい値の場合
{
//交換
int temp=a[i-1];
a[i-1] = a[j-1];
a[j-1] = temp;
}
//数の更新
i=j;
j=i*2;
}
return min;
}
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
携帯で送ったのでインデントができていなくてすみません。
ファイルの中身は、91.63.71.14.60.1.24.13.80.15です。
改良というこは、deletminで最小値を消して、並び替えるという動作を全ての数字にして欲しいということです。
No.1
- 回答日時:
あのな、まず読みづらい
インデントぐらい入れて投稿しようや
なんでこっちが読み解くところからはじめなきゃいけないんだよ
ぱっと見プログラムが完成しているように見えるけど
改良ってなんだ?
エラーが出て動作しないの?
これよりもっとステップ数を少なくしたいの?
分かりやすい書き方が知りたいの?
現状何が起きていて、どうして欲しいのかを書きなさい
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C 言語の Gauss Jordan 法について 2 2022/12/28 11:16
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# C言語 3 2022/11/09 13:27
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
へんな現象
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語での奇数の和
-
複数桁10進数の*桁目だけを抽出...
-
C言語 エラーの原因がわからな...
-
【C++】関数ポインタの使い方
-
「指定されたキャストは有効で...
-
アスタリスクでダイヤ型を作る
-
C言語 配列と関数の練習問題
-
(int *)の意味
-
比較回数と交換回数表示について
-
C言語での引数の省略方法
-
整数データの配列から同じ値の...
-
アスタリスクで正方形
-
C言語で三目並べをするプログラ...
-
C言語、行列の積を求めるプログ...
-
int型の変数値をバイト列として...
-
c言語
-
C言語の配列をC++のvectorに高...
-
異なる文字列のマッチングを、D...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語 配列と関数の練習問題
-
複数桁10進数の*桁目だけを抽出...
-
(int *)の意味
-
if と配列の組み合わせ
-
ラップ関数とはどんなものですか?
-
卒業研究でよく分からないとこ...
-
【C++】関数ポインタの使い方
-
c言語
-
足して100になるような乱数のア...
-
C言語初心者です、、、お助けく...
-
数字列を3桁ごとにカンマで区切...
-
C言語 エラーの原因がわからな...
-
実数の整数部,小数部の取得
-
課題でつまってます・・・
-
商と剰余を同時に求める(C言語)
-
C言語の配列をC++のvectorに高...
-
std::set<int> で、ある値が何...
おすすめ情報