ヒープソートについての問題です。
下のプログラムはヒープソートに格納するためのプログラムです。
この時、一つの数字を格納するたびにその時点で全体がどんな配列になっているかを表示するためには、どのように書いたらいいでしょうか?
教えてください。
よろしくお願いいたします。
void PushHeap(int x){
int i;
int oya; //親の配列
if(++n>=11){
printf("Heap Overflow\n");
exit(1);
}
else{
heap[n]=x; //数値を代入
printf(" heap[%d] 格納された数=%d\n",n,heap[n]);
i=n;
oya=i/2;
while(oya>0 && x>heap[oya]){ //親より数値が大きい
heap[i]=heap[oya]; //入れ替え
i=oya;
oya=i/2;
}
heap[i]=kazu;
if(i/2==0){
printf("親:%d\n\n",heap[i]);
}
else printf("親:%d, 子:%d\n\n",heap[i/2],heap[i]);
}
}
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
こんな感じで如何でしょう?
表示例:
6 4 5 1 3 2 0 0 0 0
root:6
left:4
left:1
left:Null
right:Null
right:3
left:Null
right:Null
right:5
left:2
left:Null
right:Null
right:Null
※1 未使用のheap[i]には0が入っていると仮定しています。
-------------------------
void PrintSPC(int n){
const char s[] = " "; // ここは半角スペース20個入れて下さい。
char *p;
int i = 2*n;
p = (char*)s;
while(*p!='\0') p++;
p -= i;
printf("%s", p);
}
char *name[3] = {"root", "left", "right"};
void PrintHeap(int idx, int indent, int kind){
if(idx >= 11 || heap[idx] == 0){ // ※1
PrintSPC(indent);
printf("%s:Null\n", name[kind]);
return;
}
PrintSPC(indent);
printf("%s:%d\n",name[kind], heap[idx]);
PrintHeap(idx*2, indent+1, 1);
PrintHeap(idx*2+1, indent+1, 2);
}
int main(void) {
int i;
PushHeap(1);
PushHeap(2);
PushHeap(3);
PushHeap(4);
PushHeap(5);
PushHeap(6);
for(i = 1; i < 11; i++) printf("%d ", heap[i]);
printf("\n");
PrintHeap(1,0,0);
return 0;
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# 10人分の生徒の英語の点数{32,34,41,38,40,26,14,46,42,50} と数学の点 2 2022/05/26 21:31
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# 至急教えてください! プログラミングの問題です! お願いします! 出力2と全く同じ出力をするように、 2 2022/06/22 23:10
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「指定されたキャストは有効で...
-
複数桁10進数の*桁目だけを抽出...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語での引数の省略方法
-
【C++】関数ポインタの使い方
-
比較回数と交換回数表示について
-
C言語で三目並べをするプログラ...
-
if と配列の組み合わせ
-
商と剰余を同時に求める(C言語)
-
C言語での奇数の和
-
ラップ関数とはどんなものですか?
-
Arduinoのプログラムにエラーが...
-
C言語
-
並列プログラミングのπ計算につ...
-
C言語 エラーの原因がわからな...
-
インライン展開されているか確...
-
GlobalAllocの変数を関数に引き...
-
HANDLEて何ですか?
-
read関数をノンブロッキングで...
-
C++でvectorにテキストファイル...
マンスリーランキングこのカテゴリの人気マンスリー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> で、ある値が何...
おすすめ情報