PTA L2-047 锦标赛

题目

解析

把每一场比赛看作满二叉树的一个节点,父节点递归遍历子节点的结果,进行试填。

代码

cpp 复制代码
#include <bits/stdc++.h>

using i64 = long long;

struct Node {
    int win, lose;
};

void solve() {
    int k;
    std::cin >> k;

    int siz = (1 << k);
    std::vector<Node> tree(siz);
    for (int r = k; r > 0; r--) {
        int n = 1 << (r - 1);
        int s = n;
        while (n--) {
            std::cin >> tree[s++].lose;
        }
    }

    std::cin >> tree[1].win;
    if (tree[1].win < tree[1].lose) {
        std::cout << "No Solution\n";
    } else {
        std::function<bool(int, int)> dfs = [&] (int u, int siz) -> bool {
            if (u * 2 >= siz) {
                return true;
            }
            int l = u * 2, r = u * 2 + 1;
            int faw = tree[u].win, fal = tree[u].lose;
            if (faw > tree[l].lose && fal > tree[r].lose) {
                tree[l].win = faw;
                tree[r].win = fal;
                if (dfs(l, siz) && dfs(r, siz)) {
                    return true;
                }
                tree[l].win = tree[r].win = 0;
            }
            if (faw > tree[r].lose && fal > tree[l].lose) {
                tree[r].win = faw;
                tree[l].win = fal;
                if (dfs(l, siz) && dfs(r, siz)) {
                    return true;
                }
            }
            return false;
        };
        if (dfs(1, siz)) {
            for (int i = (1 << (k - 1)); i < siz; i++) {
                std::cout << tree[i].win << " " << tree[i].lose;
                if (i != siz - 1) std::cout << " ";
            }
        } else {
            std::cout << "No Solution\n";
        }
    }

    
}

int main() {
    std::ios_base::sync_with_stdio(false);
    std::cin.tie(nullptr); 

    int t = 1;
    // std::cin >> t;

    for (int i = 1; i <= t; i++) {
        // std::cout << "Case " << i << ": ";
        solve();
    }

    return 0;
}
相关推荐
计算机小白一个5 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^5 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿7 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!7 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉7 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生7 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴8 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing8 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财8 小时前
加油站(力扣134)
算法·leetcode·职场和发展
王老师青少年编程8 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛