c++二叉树寒假特训题目(1)答案你

news2024/11/15 8:30:32

大家好,我是周曦,今天给大家写了c++二叉树寒假特训题目(1)的答案。

题目传送门

答案

二叉树存储

思路

存储部分可以用满二叉树的性质,设深度为k,那么一共有2的k次方减1个数,最多是1024个。计算与输出部分因为是满二叉树,我们可以计算一个节点在第几层,如果一个节点大于2ⁿ⁻¹,那么他是在最后一层,没有子节点就输出none,否则输出下标为x*2和x*2+1的点。注意要换行。

代码

#include<bits/stdc++.h>
using namespace std;
int n,x;
int a[1024];
int main(){
    cin>>n;
    for(int i=1;i<=pow(2,n)-1;i++){
        cin>>a[i];
    }
    cin>>x;
    if(x>=pow(2,n-1)){
        cout<<"none";
    }else{
        cout<<a[x*2]<<" "<<a[x*2+1];
    }
    return 0;
}

淘汰赛

思路

这一题我是用了一种类似动态规划的做法:先建一个2ⁿ*2的数组,输入部分在2ⁿ到2ⁿ*2-1,接来看图(以n=3为例):

也就是将下标为i*2和i*2+1的打擂台,而亚军就是下标为2和3中的最小值。

代码

#include<bits/stdc++.h>
using namespace std;
map<string,int> m;
int n,x;
int a[10001];
int t[10001];
int main(){
    cin>>n;
    for(int i=pow(2,n);i<=pow(2,n)*2-1;i++){
        cin>>a[i];
        t[a[i]]=i-pow(2,n)+1;
    }
    for(int i=pow(2,n)-1;i>=1;i--){
        a[i]=max(a[i*2],a[i*2+1]);
        //cout<<a[i]<<" ";
    }
    cout<<t[min(a[2],a[3])];
    return 0;
}

前序遍历

思路

这题很简单,一个结构体ok,dfs顺序记住,先输出,再遍历做儿子,最后遍历右儿子,直接上代码。

代码

#include<iostream>
using namespace std;
int n;
struct node{
    int l,r;
    char z;
}ans[10001];
void dfs(int i){
    if(i!=0){
        cout<<ans[i].z;
        dfs(ans[i].l);
        dfs(ans[i].r);
    }
    
}
int main(){
    cin>>n;
    for(int i=1;i<=n;i++) cin>>ans[i].z>>ans[i].l>>ans[i].r;
    dfs(1);
    return 0;
}

中序遍历与后序遍历

说明

只需要把上一题dfs里的顺序改一下就行,此处不多讲。

子树的大小

思路

首先一个循环求深度,在判断得了,太水了,直接上代码。

代码

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,m,cnt=1;
    cin>>m>>n;
    int x=m;
    while(x*2+1<=n){
        cnt++;
        x=x*2+1;
    }
    int ans=pow(2,cnt)-1;
    int l=m*pow(2,cnt);
    if(l>n) cout<<ans;
    else cout<<ans+(n-l+1);
    return 0;
}

结点的查找

思路

看上去yyds,实际上想到就是道水题,全代码只有两个循环,一个来输入,一个求k层理论上的的最左和最右的节点编号。首先输入,一个大while包着全部,再一个while求k层理论上的的最左和最右的节点编号,接下来判断,如果左子节点编号大于n,那直接输出EMPTY,如果左右子节点都小于等于n,输出从左子节点到右子节点中的所有编号,换行,如果右子节点大于n但左子节点小于等于n,输出左子节点到n。

代码(你们最喜欢的copy环节!)

#include<bits/stdc++.h>
using namespace std;
int n,k;
int main(){
    while(cin>>n>>k){
        int bas=1,vol=1;
        for(int i=1;i<=k-1;i++){
            bas*=2;
            vol*=2;
            vol+=1;
        }
        if(bas>n){
            cout<<"EMPTY"<<endl;
        }else{
            if(vol<=n){
                for(int i=bas;i<=vol;i++){
                    cout<<i<<" ";
                }
                cout<<endl;
            }else{
                if(vol>n&&bas<=n){
                    for(int i=bas;i<=n;i++){
                        cout<<i<<" ";
                    }
                    cout<<endl;
                }
            }
        }


    }
    return 0;
}

总结

这次的题真的水,不知道是题里掺了点水还是水里掺了点题,第一题主要考了概念,对二叉树不熟的是无法确定要输入几次和最后的判断条件。第二题动态规划和二叉树基本概念学得好也是不成问题的。前中后序遍历用我给的模板写是有手就行。子树的大小有些难,我用了十分钟才搞定的。最后一题想通了也蛮简单了。

总的来说,只要以前的算法和二叉树概念过关,是可以轻松AK题单的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1440083.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

跟着pink老师前端入门教程-day21+22

5.4 常见flex布局思路 5.5 背景线性渐变 语法&#xff1a; background: linear-gradient( 起始方向 , 颜色 1, 颜色 2, ...); background: -webkit-linear-gradient(left, red , blue); background: -webkit-linear-gradient(left top, red , blue); 背景渐变必须添加浏览…

vue项目打包部署到flask等后端服务里面,实现前后端不分离部署,解决空白页面和刷新页面not fount问题

1. 编译模式一定要设置为esnext&#xff0c;否则会报错&#xff1a; Strict MIME type checking is enforced for module scripts per HTML spec.Expected a JavaScript module script but the server responded with a MIME type of "text/plain". 具体解释可以看vi…

解决CORS错误(Spring Boot)

记录一下错误&#xff0c;以博客的形式 前言 跨域&#xff08;Cross-Origin&#xff09;是指在Web开发中&#xff0c;当一个Web应用试图从一个源&#xff08;域名、协议、端口组合&#xff09;获取资源时&#xff0c;该请求的目标与当前页面的源不同。具体来说&#xff0c;当一…

Docker容器监控-CIG

目录 一、CIG说明 1. CAdvisor 2. InfluxDB 3. Grafana 二、环境搭建 1. 创建目录 2. 编写 docker-compose.yml 3. 检查并运行容器 三、进行测试 1. 查看 influxdb 存储服务 是否能正常访问 2. 查看 cAdvisor 收集服务能否正常访问 3. 查看 grafana 展现服务&#…

Alt + TAB 禁止在 Edge 标签页之间切换

&#xff08;原文&#xff1a;https://blog.iyatt.com/?p13587 &#xff09; 浏览器标签页之间切换可以用 {Ctrl}{Tab} 或者 {Ctrl}{数字}精准到标签页码&#xff0c;结果 Windows 11 默认把 Edge 标签页切换混入了 {Alt}{Tab} 前台应用窗口切换&#xff0c;经常不注意是在 Ed…

2.8作业

程序代码&#xff1a; CCgcc EXEhello OBJS$(patsubst %.c,%.o,$(wildcard *.c)) CFLAGS-c -oall:$(EXE)$(EXE):$(OBJS)$(CC) $^ -o $%.o:%.c$(CC) $(CFLAGS) $ $^.PHONY:cleanclean:rm $(OBJS) $(EXE) 程序代码&#xff1a; #include<stdio.h> #include<string.h&…

跨境电商新风潮:充分发挥海外云手机的威力

在互联网行业迅速发展的大环境下&#xff0c;跨境电商、海外社交媒体营销以及游戏产业等重要领域都越来越需要借助海外云手机的协助。 特别是在蓬勃发展的跨境电商领域&#xff0c;像亚马逊、速卖通、eBay等平台&#xff0c;结合社交电商营销和短视频内容成为最有效的流量来源。…

什么是美颜SDK?直播美颜SDK的技术原理与应用

当下&#xff0c;美颜SDK的崛起成为了直播美颜的关键推动力。今天&#xff0c;小编将为大家讲解美颜SDK的概念、技术原理以及在直播应用中的广泛应用。 一、什么是美颜SDK&#xff1f; 美颜SDK是一种软件开发工具包&#xff0c;旨在为应用开发者提供一整套美颜算法和功能&…

Sklearn、TensorFlow 与 Keras 机器学习实用指南第三版(八)

原文&#xff1a;Hands-On Machine Learning with Scikit-Learn, Keras, and TensorFlow 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 第十八章&#xff1a;强化学习 强化学习&#xff08;RL&#xff09;是当今最激动人心的机器学习领域之一&#xff0c;也是最古老…

完全背包理论基础 C++力扣题目518--零钱兑换II

动态规划&#xff1a;完全背包理论基础 本题力扣上没有原题&#xff0c;大家可以去卡码网第52题 (opens new window) #思路 #完全背包 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i]&#xff0c;得到的价值是value[i] 。每件物品都有无限个&#xff0…

【MySQL】学习和总结DCL的权限控制

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-Bl9kYeLf8GfpdQgL {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

《动手学深度学习(PyTorch版)》笔记7.2

注&#xff1a;书中对代码的讲解并不详细&#xff0c;本文对很多细节做了详细注释。另外&#xff0c;书上的源代码是在Jupyter Notebook上运行的&#xff0c;较为分散&#xff0c;本文将代码集中起来&#xff0c;并加以完善&#xff0c;全部用vscode在python 3.9.18下测试通过&…

深度学习中常用激活函数介绍

深度学习中常用激活函数介绍 在深度学习中&#xff0c;激活函数的作用主要是引入非线性特性&#xff0c;提高模型的表达能力。具体如下&#xff1a; 解决线性不可分问题&#xff1a;激活函数可以将输入特征的复杂度提升&#xff0c;使得神经网络能够处理非线性问题&#xff0c…

OpenAI推出ChatGPT已经过去一年多了,AI 取代了内容创作者吗

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

【Python基础】案例分析:GDP分析

GDP分析 文章目录 GDP分析1 分析过程与目标1.1 数据来源1.2 熟悉数据 2 各国与地区GDP数据分析关系多源组成2.2 清洗数据2.3 设定分析目标 3 主要国家DGP分析3.1 主要国家GDP趋势3.2 1990年开始GDP对比 4 中国GDP分析4.1 从1990年开始GDP变化化4.2 中国GDP分析增长超过10%的年份…

C# 使用 MailKit 发送邮件(附demo)

C# 使用 MailKit 发送邮件&#xff08;附demo&#xff09; 介绍安装包&#xff08;依赖&#xff09;案例简单代码属性介绍&#xff1a;MailboxAddress属性介绍&#xff1a;BodyBuilderSMTP 服务器端口SSL的案例&#xff1a;非SSL&#xff1a; 介绍一下SMTP 介绍 MailKit 是一…

【力扣】盛最多水的容器,双指针法

盛最多水的容器原题地址 方法一&#xff1a;双指针 如果使用暴力枚举&#xff0c;时间复杂度为 &#xff0c;效率太低&#xff0c;会超时。 考虑使用双指针&#xff0c;利用单调性求解。用 left 和 right 作为数组 height 的下标&#xff0c;分别初始化为 0 和 size-1 。考…

容器库(6)-std::set

std::set是以key为元素的关联容器&#xff0c;容器中的key是唯一的且按顺序排列的。搜索、移除和插入的时间复杂度是 。底层通常是以红黑树实现的。 template<class Key,class Compare std::less<Key>,class Allocator std::allocator<Key> > class set; …

华为配置内部人员接入WLAN网络示例(802.1X认证)

配置内部人员接入WLAN网络示例&#xff08;802.1X认证&#xff09; 组网图形 图1 配置802.1X认证组网图 业务需求组网需求数据规划配置思路配置注意事项操作步骤配置文件 业务需求 用户接入WLAN网络&#xff0c;使用802.1X客户端进行认证&#xff0c;输入正确的用户名和密…

背包问题(01背包、完全背包、多重背包)详解(超详细!!!),及题目代码和题意,包含6个例题。

第一题&#xff1a;01背包问题 01背包问题 时间限制&#xff1a;1秒 内存限制&#xff1a;128M 题目描述 一个旅行者有一个最多能装 M 公斤的背包&#xff0c;现在有 n 件物品&#xff0c;它们的重量分别是 W1&#xff0c;W2&#xff0c;...,Wn ,它们的价值分别为 C1…