码迷,mamicode.com
首页 > 其他好文 > 详细

uva 10821 - Constructing BST(BSF)

时间:2014-09-16 17:28:21      阅读:254      评论:0      收藏:0      [点我收藏+]

标签:style   http   color   io   os   ar   sp   cti   on   

题目链接:uva 10821 - Constructing BST

题目大意:给定节点个数以及树的高度,求一个字典序最小的插入顺序,使得生成的BST高度为H。

解题思路:根据H来确定说左右子树的节点个数,因为要求字典序尽量小,所以右子树的节点个数应该尽量多。

#include <cstdio>
#include <cstring>
#include <algorithm>

using namespace std;

int N, H;

void solve (int l, int r, int h) {
    if (l > r)
        return;

    int mid = max(r - (1<<h) + 1, l);
    printf(" %d", mid);
    solve(l, mid - 1, h - 1);
    solve(mid + 1, r, h - 1);
}

int main () {
    int cas = 0;
    while (scanf("%d%d", &N, &H) == 2 && N + H) {
        printf("Case %d:", ++cas);
        if (N > (1<<H) - 1)
            printf(" Impossible.");
        else
            solve(1, N, H - 1);
        printf("\n");
    }
    return 0;
}

uva 10821 - Constructing BST(BSF)

标签:style   http   color   io   os   ar   sp   cti   on   

原文地址:http://blog.csdn.net/keshuai19940722/article/details/39297425

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!