poj2418Hardwood Species

编辑器加载中...

题目:

       给出一些树名,问每一棵树的所占的比例

分析:

       就是给树按字典序排序,并输出他们所占的比例,由于本题涉及的树名比较多,可以采用

       二分搜索树来做,然后按照中序遍历即可

 

#include <iostream>

#include <cstdio>

#include <cstring>

using namespace std;

#define X 50

int cnt;

struct node     //树的结构体

{

       int id;                    //储存个数的

       char name[X];       //储存名字

       node *rchild;   //右子树

       node *lchild;   //左子树

};

char in[X];

struct node *insert(node *r,char in[X],int len)//插入树名

{

       if(r==NULL)          //当当前位置为空时,直接插入到该位置即可

       {

              r = new node; //申请新的节点

              strcpy(r->name,in);//把该树名储存到结构体的数组中

              r->id = 1;              //因为这是一棵新的树,所以暂时它的数目为1

              r->lchild = NULL;//左右子树置空

              r->rchild = NULL;

       }

       else

       {

              if(strcmp(r->name,in)>0)      //比节点的字典序小时,递归插入到左子树中

                     r->lchild = insert(r->lchild,in,len);

              else if(strcmp(r->name,in)<0)       //比节点的字典序大时,递归插入到右子树中

                     r->rchild = insert(r->rchild,in,len);

              else  //当相等时,直接数目加一即可

                     r->id++;

       }

       return r;

}

void inorder(node *r)     //中序遍历

{

       if(r!=NULL)

       {

              inorder(r->lchild);

              printf("%s %.4lf\n",r->name,r->id*100.0/cnt);//打印树名和百分比

              inorder(r->rchild);

       }

}

int main()

{

       freopen("sum.in","r",stdin);

       freopen("sum.out","w",stdout);

       cnt = 0;

       node *r;

       r = NULL;

       while(gets(in))

       {

              cnt++;

              int len = strlen(in);

              r = insert(r,in,len);//把新输入的树名插入到结构体中

       }

       inorder(r);      //中序遍历

       return 0;

}

你可能感兴趣的:(poj)