数据结构题目-二叉排序树

2023-11-06

目录

问题 A: 二叉排序树 - 文本输出

问题 B: 销售排行榜 

问题 C: 二叉排序树-平衡因子 

问题 D: 案例 1-1.1 二分查找

问题 E: 进阶实验 1-3.1:两个有序序列的中位数


问题 A: 二叉排序树 - 文本输出

题目描述

给定一个序列,使用该序列生成二叉排序树(也叫二叉搜索树,BST),然后以本题规定方法输出该二叉排序树。
例:
给定一个序列:43 25 29 67 17 88 54 47 35 62
以第一个数字43)为根节点,然后将后面的数字依输入次序逐个添加至该树中,得到一个二叉排序树,如下图所示。


然后先序遍历上面这个树,并按行输出数字。
其中每个子节点的输出前,需要相较于其父节点前多四个普通空格。
当某个节点为叶子节点(即无子节点),则该节点的左右叶子节点均不用输出。
而当某个节点仅有左叶子节点或右叶子节点时,另一个空缺的子节点用#占位。


以该图为例,其最终输出结果为:
43
    25
        17
        29
            #
            35
    67
        54
            47
            62
        88

输入格式

第一行为正整数n,表示接下来将输入的节点数量。(n<500)
第二行为n个正整数,每个数字以空格分隔(以第一个数字为根节点)

输出格式

以题目描述中的方法输出得到的二叉排序树。
以第一个数字为根节点,然后将后面的数字依输入次序逐个添加至该树中,得到一个二叉排序树。
然后先序遍历该树,并按行输出数字。
其中每个子节点的输出前,需要相较于其父节点前多四个普通空格。
当某个节点为叶子节点(即无子节点),则该节点的左右叶子节点均不用输出。
而当某个节点仅有左叶子节点或右叶子节点时,另一个空缺的子节点用#占位。
 

输入样例 复制

10
43 25 29 67 17 88 54 47 35 62

输出样例 复制

43
    25
        17
        29
            #
            35
    67
        54
            47
            62
        88
#include<bits/stdc++.h>
using namespace std;
 
typedef struct node{
    int data;
    node *rchild;
    node *lchild;
}Node,*Tree;
 
 
void creat(Tree &tree,int num)
{
    Tree node = new Node;
    node->data=num;
    node->lchild=NULL;
    node->rchild=NULL;
    if(tree==NULL)
    {
        tree=node;
    }
    else if(num>tree->data)
    {
        creat(tree->rchild,num);
    }
    else
    {
        creat(tree->lchild,num);
    }
}
 
 
void print(Tree tree,int i)
{
    if(tree==NULL)
    return;
    for(int j=0;j<i;j++)
    cout<<"    ";
    cout<<tree->data<<endl;
    i++;
    if(tree->lchild==NULL&&tree->rchild!=NULL)
    {
        for(int j=0;j<i;j++)
        cout<<"    ";
        cout<<"#"<<endl;
    }
    print(tree->lchild,i);
    print(tree->rchild,i);
    if(tree->lchild!=NULL&&tree->rchild==NULL)
    {
        for(int j=0;j<i;j++)
        cout<<"    ";
        cout<<"#"<<endl;
    }
}
 
int main()
{
    int n;
    cin>>n;
    int a[505];
    Tree tree;
    tree=new Node;
    tree=NULL;
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }
    for(int i=0;i<n;i++)
    {
        creat(tree,a[i]);
    }
    print(tree,0);
    return 0;
}

问题 B: 销售排行榜 

题目描述

你的任务是帮助淘宝网店店长整理销售数据,根据累计的销售记录,将所有商品按销售数量降序排列。

输入格式

输入包括多行数据(行数小于100000),每行数据包括4个信息,分别是商品名称、销售数量、单价、成交日期

商品名称由小写字母组成,且不超过100个字符,销售数量和单价都是正整数,且小于10000

输出格式

输出包括多行数据,将所有在输入中出现的商品按销售数量降序排列,每行数据包括3个信息,分别是商品名称、销售数量、销售额,如果两种商品销售数量一样,则按商品的字母顺序升序排列

输入样例 复制

apple 1 20 2014-4-2 
basketball 1 20 2014-4-2
computer 1 20 2014-4-2
shoe 1 20 2014-4-2
tv 1 20 2014-4-2
apple 1 18 2014-4-3 

输出样例 复制

apple 2 38
basketball 1 20
computer 1 20
shoe 1 20
tv 1 20
#include<bits/stdc++.h>
using namespace std;
struct info{
    string name;
    int num;
    int price;
    int flag=1;
    int all=0;
}a[100005];
 
bool mysort1(struct info c,struct info d)
{
    return c.name<d.name;
}
 
bool mysort2(struct info c,struct info d)
{
    if(c.num==d.num)
    return c.name<d.name;
    else
    return c.num>d.num;
}
 
int main()
{
    string name;
    int num;
    int price;
    string date;
    int index=0;
    while(cin>>name>>num>>price>>date)
    {
        a[index].price=price;
        a[index].name=name;
        a[index].num=num;
        a[index].all=num*price;
        index++;
        // if(index==6)
        // break;
    }
    sort(a,a+index,mysort1);
    for(int i=1;i<index;i++)
    {
        if(a[i].name==a[i-1].name)
        {
            a[i-1].flag=0;
            a[i].num+=a[i-1].num;
            a[i].all+=a[i-1].all;
        }
    }
    sort(a,a+index,mysort2);
    for(int i=0;i<index;i++)
    {
        if(a[i].flag==1)
        cout<<a[i].name<<" "<<a[i].num<<" "<<a[i].all<<endl;
    }
}

问题 C: 二叉排序树-平衡因子 

题目描述

给定一个序列,使用该序列生成二叉排序树,然后以本题规定方法输出该二叉排序树。
例:
给定一个序列:43 25 29 67 17 88 54 47 35 62
以第一个数字(43)为根节点,然后将后面的数字依输入次序逐个添加至该树中,得到一个二叉排序树

然后先序遍历上面这个树,并按行输出数字。
其中每个子节点的输出前,需要相较于其父节点前多四个普通空格。
当某个节点为叶子节点(即无子节点),则该节点的左右叶子节点均不用输出。
而当某个节点仅有左叶子节点或右叶子节点时,另一个空缺的子节点用#占位。
对于非空的节点,求出其平衡因子,并用括号括起来输出在结果中
以该图为例,其最终输出结果为:
43(0)
    25(-1)
        17(0)
        29(-1)
            #
            35(0)
    67(1)
        54(0)
            47(0)
            62(0)
        88(0)

输入样例 复制

10
43 25 29 67 17 88 54 47 35 62

输出样例 复制

43(0)​
    25(-1)
        17(0)
        29(-1)
            #
            35(0)
    67(1)
        54(0)
            47(0)
            62(0)
        88(0)
#include<bits/stdc++.h>
using namespace std;
 
typedef struct node{
    int data;
    int height=0;
    node *rchild;
    node *lchild;
}Node,*Tree;
 
int depth=0;

int height(Tree &t)
{
    if(t==NULL)
    return 0;
    t->height=max(height(t->lchild),height(t->rchild))+1;
    return t->height;
}


 
void creat(Tree &tree,int num)
{
    Tree node = new Node;
    node->data=num;
    node->lchild=NULL;
    node->rchild=NULL;
    if(tree==NULL)
    {
        tree=node;
    }
    else if(num>tree->data)
    {
        creat(tree->rchild,num);
    }
    else
    {
        creat(tree->lchild,num);
    }
}
 
 
void print(Tree tree,int i)
{
    if(tree==NULL)
    return;
    for(int j=0;j<i;j++)
    cout<<"    ";
    cout<<tree->data;
    if(tree->lchild==NULL&&tree->rchild==NULL)
    cout<<"("<<0<<")"<<endl;
    else if(tree->lchild==NULL&&tree->rchild!=NULL)
    cout<<"("<<tree->rchild->height*-1<<")"<<endl;
    else if(tree->lchild!=NULL&&tree->rchild==NULL)
    cout<<"("<<tree->lchild->height<<")"<<endl;
    else
    cout<<"("<<tree->lchild->height-tree->rchild->height<<")"<<endl;
    i++;
    if(tree->lchild==NULL&&tree->rchild!=NULL)
    {
        for(int j=0;j<i;j++)
        cout<<"    ";
        cout<<"#"<<endl;
    }
    print(tree->lchild,i);
    print(tree->rchild,i);
    if(tree->lchild!=NULL&&tree->rchild==NULL)
    {
        for(int j=0;j<i;j++)
        cout<<"    ";
        cout<<"#"<<endl;
    }
}
 
int main()
{
    int n;
    cin>>n;
    int a[505];
    Tree tree;
    tree=new Node;
    tree=NULL;
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }
    for(int i=0;i<n;i++)
    {
        creat(tree,a[i]);
    }
    height(tree);
    print(tree,0);
    return 0;
}

问题 D: 案例 1-1.1 二分查找

题目描述

  给定大小为N(0<N<1000),从小到大排列的整数数组A[],以及待查找的整数X,目的是找到X在数组A[]中第一次出现的位置并输出。如没有找到则输出-1;

输入格式

第一行 数组大小 N
第二行 数组A[]
第三行 带查找的整数X

输出格式

如找到X,则输出第一次出现的位置。如未找到,则输出-1。

输入样例 复制

5
1 2 4 4 5 
4

输出样例 复制

3
#include<bits/stdc++.h>
using namespace std;
int a[1005];

int main()
{
    int n;
    cin>>n;
    int t;
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }
    cin>>t;
     for(int i=0;i<n;i++)
     {
        if(a[i]==t)
        {
            cout<<i+1;
            return 0;
        }
     }
     cout<<-1;
}

问题 E: 进阶实验 1-3.1:两个有序序列的中位数

题目描述

    已知有两个等长非降序序列S1,S2。先将S1,S2合并为S3,求S3的中位数。长度为N的非降序序列SN的中位数为第X个数,X=不超过(N+1)/2的最大整数。

输入格式

第一行,序列S1,S2的长度N
第二行,序列S1的N个整数
第三行,序列S2的N个整数

输出格式

输出两个序列合并后序列S3的中位数

输入样例 复制

5
1 3 5 7 9
2 3 4 5 6

输出样例 复制

4
//这里耍了个小聪明,没有合并,不要学我
#include<bits/stdc++.h>
using namespace std;
int a[10005];
int b[10005];

int main()
{
    int n;
    int index=0;
    cin>>n;
    for(int i=0;i<n;i++)
    cin>>a[i];
    for(int i=0;i<n;i++)
    cin>>b[i];
    int i=0,j=0;
    while(1)
    {
        int temp=0;
        if(a[i]<=b[j])
        {
            temp=a[i];
            i++;
        }
        else
        {
            temp=b[j];
            j++;
        }
        index++;
        if(index==n)
        {
            cout<<temp;
            return 0;
        }
    }
    return 0;
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

数据结构题目-二叉排序树 的相关文章

随机推荐

  • Linux中在线yum源的配置

    在线源的配置 配置环境 root localhost cat etc redhat release CentOS release 6 5 Final root localhost uname r 2 6 32 431 el6 x86 64
  • c语言六子棋(Alpha-Beta剪枝算法)

    c语言Alpha Beta剪枝算法六子棋 介绍 Alpha Beta剪枝算法是一种用于优化博弈树搜索的算法 可以在搜索过程中减少不必要的计算 从而提高搜索效率 该算法常用于博弈游戏 如六子棋 六子棋是一种类似于五子棋的棋类游戏 在一个六边形
  • 响应支付宝宣布的刷脸支付商业化

    二维码普及才没多久 刷脸支付已经悄无声息的走进我们的生活 刷脸支付作为一种全新的支付方式 将彻底改变人类的生活方式 有些人感慨道 这个时代变化太快了 快到一切技术的发展犹如坐上了火箭 去年8月中下旬 广电运通与深圳地铁腾讯共同打造生物识别
  • 为什么选择SpringCloud

    SpringCloud的诞生 SpringCloud是集成了众多开源的框架 利用SpringBoot的开发便利性实现服务治理 服务注册与发现 负载均衡 数据监控 REST API发布方式等 基本囊括了分布式框架所需要的所有功能 是一套易开放
  • 饮冰l于 2021-02-05 15:16:54 发布 1288收藏 11分类专栏: 图 文章标签: 算法 数据挖掘 机器学习 深度学习版权图 专栏收录该内容66 篇文章 23 订阅订

    前言 本文的作者认为对于 GNN 的可解释性不足 基于此 作者在节点分类任务上提出可以通过将忽略图结构的浅层模型与两个利用标签结构中相关性的后处理方法相结合 超越或匹配最先进的 GNN 具体如下 i 误差相关性 传播训练数据中的残余误差以纠
  • CMake编程实践(五) 编译静态库和动态库

    使用Cmake 编译库 本篇使用CMake编译一个动态库和静态库 并安装到系统中 对应的工程是cmake utilsbox lib 编译静态库 指定编译静态库 关键词为static 不添加关键字默认静态库 add library utils
  • 存档用【20考研】国家线/34所自划线 集合!【计算机和软件专业】

    为了同学们更方便快捷的了解34所院校的自划线和国家分数线 小编在这里开了一个专区 提供给同学们计算机 软件工程等相关专业的考研分数线 这是20考研的数据 我发现当时没有发 现在发一下存档用的 不发没办法设置链接 什么是A类 什么是B类 可以
  • 【Windows】如何使用Windbg检测Windows程序内存泄漏

    文章目录 使用Windbg检测Windows程序内存泄漏的步骤如下 启动程序 使用Windbg启动需要检测内存泄漏的程序 可以通过在Windbg中选择 文件 gt 打开程序 来打开程序 设置符号路径 在Windbg中 可以通过设置符号路径来
  • python 多线程模拟多用户访问接口

    coding utf 8 import threading import requests from urllib parse import quote 定义访问接口的函数 def access api user id params E4
  • Kafka数据丢失原因及解决方案

    Kafka包括Producer Broker Consumer 因此从这三个方面分析 Producer端 丢失原因 Kafka在Producer端的消息发送采用的是异步发送的方式 还有同步发送 但是同步发送会导致消息阻塞 需要等待 丢失数据
  • XSS漏洞学习

    原理 XSS攻击通常指的是通过利用网页开发时留下的漏洞 通过巧妙的方法注入恶意指令代码到网页 使用户加载并执行攻击者恶意制造的网页程序 这些恶意网页程序通常是JavaScript 但实际上也可以包括Java VBScript ActiveX
  • openmpi参数_Open MPI的目标、概念及实现

    目前 许多可用的MPI实现只关注HPC 高性能计算 的部分方面或是专注于解决某个具体问题 这导致了这些MPI实现不兼容 如果独立安装组合来获取它们的特有功能 Open MPI是在LAM MPI LA MPI and FT MPI的基础上的一
  • 目标检测如何计算召回率_目标检测+准确率、召回率、PR曲线、AP、mAp、mmAp

    查准率 查全率 AP map 参考知乎地址 https zhuanlan zhihu com p 94597205 TP True Positive 一个正确的检测 检测的IOU threshold 即预测的边界框 bounding box
  • JavaScript中常用的三种弹窗

    目录 一 alert 警告框 二 confirm 确认框 三 prompt 提示框 JavaScript 中可以创建三种消息框 警告框 确认框 提示框 一 alert 警告框 alert 方法是显示一条弹出提示消息和确认按钮的警告框 需要注
  • 【js】删除数组中的指定元素,且不改变原数组

    笨办法 export function remove arr item let result arr forEach function element if element item result push element return r
  • 样本不平衡问题分析与部分解决办法

    最近工作中在处理文本分类问题遇到了分类不均衡的问题 主要还是样本太少还同时非常的不均衡正负样本1 10 类别不平衡比例超过4 1 就会造成偏移 就使用了SMOTE方法 注意 在进行数据增广的时候一定要将测试集和验证集单独提前分开 扩张只在训
  • Doxygen简介及使用说明

    https blog csdn net Candy1232009 article details 80786179
  • java的String字符串拼接和StringBuffer的append的速度差异

    今天在leetcode上做题的时候发现 实现字符串拼接的时候 用StringBuffer的append比String的 快很多 思考了一下这两者的差别 我是初学者 有说错的还请大家指正 首先得出String的 拼接的时间 public st
  • Linux下多线程编程思考与学习----01(线程创建pthread_create函数详解)

    一 为什么需要使用多线程编程 当在执行某些程序的时候难免会需要同时执行两个 甚至多个任务 当然可以使用多个进程进行执行 但是难免需要用到信息的传输 因此就需要引入进程间通信的问题 这对于CPU内存调度的压力也会更大 多线程编程的优点是在同一
  • 数据结构题目-二叉排序树

    目录 问题 A 二叉排序树 文本输出 问题 B 销售排行榜 问题 C 二叉排序树 平衡因子 问题 D 案例 1 1 1 二分查找 问题 E 进阶实验 1 3 1 两个有序序列的中位数 问题 A 二叉排序树 文本输出 题目描述 给定一个序列