#include<iostream>
#include<algorithm>
using namespace std;
#define maxn 10
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" int a[]= {0,1,2,3,4,5,6,7,8,9};
struct node
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" {
int key;
struct node * lchild,*rchild;
};
node * create(int pos)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" {
if(pos>=maxn)
return NULL;
node * root=(node*)malloc(sizeof(node));
root->key=a[pos];
root->lchild=create(2*pos);
root->rchild=create(2*pos+1);
return root;
}
void levelorder(node * root)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" {
node * q[maxn];
int top,tail;
top=0,tail=1;
q[0]=root;
while(top<tail)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" {
printf("%d\n",q[top]->key);
if(q[top]->lchild!=NULL)
q[tail++]=q[top]->lchild;
if(q[top]->rchild!=NULL)
q[tail++]=q[top]->rchild;
top++;
}
}
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" {
levelorder(create(1));
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
|