Contest2850 - 【在线编程平台】2022年计算机类数据结构作业12.20221201-1206

news2025/1/10 1:59:51

问题 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;
}

 

 

 

 

 

 

 

 

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

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

相关文章

用R语言制作交互式图表和地图

可以直接从R / RStudio制作在线交互式图表和地图。 去年&#xff0c;我们为一位客户进行了短暂的咨询工作&#xff0c;他正在构建一个主要基于在线交互式图表的分析应用程序。 配置 启动RStudio&#xff0c;创建一个新的RScript&#xff0c;然后将工作目录设置为下载的数据文…

git merge origin master和git merge master的区别(个人理解)

先说结论 git merge origin master 意思是当前的分支,进行合并,合并二个分支分别是远程分支master在本地的副本和本地分支的master git merge master 当前分支于本地所处的master分支进行合并 还有就是 git merge origin master是把origin merge 到 master 上的说法是错误的…

小侃设计模式(十五)-命令模式

1.概述 命令模式&#xff08;Command Pattern&#xff09;是将一个请求封装为一个对象&#xff0c;从而让你使用不同的请求把客户端参数化&#xff0c;对请求排队或者记录请求日志&#xff0c;可以提供命令的撤销和恢复功能。它是行为型模式的一种&#xff0c;能够有效降低系统…

【华为上机真题 2022】流水线

&#x1f388; 作者&#xff1a;Linux猿 &#x1f388; 简介&#xff1a;CSDN博客专家&#x1f3c6;&#xff0c;华为云享专家&#x1f3c6;&#xff0c;Linux、C/C、云计算、物联网、面试、刷题、算法尽管咨询我&#xff0c;关注我&#xff0c;有问题私聊&#xff01; &…

ES6:ES6 的内置对象扩展

Array 的扩展方法 扩展运算符&#xff08;展开语法&#xff09; 扩展运算符可以将数组或者对象转为用逗号分隔的参数序列。 let ary [1, 2, 3];...ary // 1, 2, 3console.log(...ary); // 1 2 3console.log(1, 2, 3)为什么没有逗号&#xff0c;这个是因为被当做console…

毕业设计-机器视觉的疲劳驾驶检测系统-python-opencv

目录 前言 课题背景和意义 实现技术思路 实现效果图样例 前言 &#x1f4c5;大四是整个大学期间最忙碌的时光,一边要忙着备考或实习为毕业后面临的就业升学做准备,一边要为毕业设计耗费大量精力。近几年各个学校要求的毕设项目越来越难,有不少课题是研究生级别难度的,对本科…

买家的诉求决定你的产品卖点

产品卖点的核心是消费者的诉求&#xff0c;也就是消费者为什么对某个产品有需求。 为什么要用广角镜头&#xff1f;可能要拍比较大、比较宏伟的环境。 为什么要用微距&#xff1f;可能要去拍一些细节场景。 …… 很多时候跟客户对不上&#xff0c;是因为不知道客户具体要做…

挨个排列原子!美国科学家打造出全新量子试验台

11月29日&#xff0c;美国科学家建立了一个原子级精度的测试平台&#xff0c;能以全新的方式操纵电子&#xff0c;在量子计算中有着巨大潜力。电子是微观粒子&#xff0c;可以在材料和设备之间携带电量和信息。它们通常可视为离散的小球&#xff0c;在电路中或原子周围移动。虽…

Git下载安装及环境配置,解决安装包下载慢问题(详细版)

Git是我们平时开发都要用到的项目管理工具&#xff0c;虽然有网页版的Git网站&#xff0c;但是在本地安装Git后&#xff0c;可以直接使用命令语句来进行项目的上传与克隆。还是非常方便的。 今天就来介绍下Git的下载。 git下载安装一、下载二、安装git三种操作界面的简介三、设…

不同应用选择荧光染料 -CY7 ALK脂溶性Sulfo-Cyanine7 alkyne 结构式应用

不同应用选择荧光染料-多肽、蛋白、抗体标记、活体成像 荧光标记技术是指运用荧光染料与待研究对象结合&#xff0c;利用它的荧光特性&#xff0c;提供待研究对象相关信息。荧光标记具有操作简便、高稳定性、高灵敏度等优势&#xff0c;使荧光染料在生命科学研究中应用&#xf…

软件测试之对于测试的反思及思考

1.针对一个页面&#xff0c;从页面的完整性(包括字段、输入框、功能点)出发 2.对于分页&#xff0c;考虑未在首页的时候的测试&#xff0c;末页的情况。 3.对条件的查询来说&#xff0c;要针对于单个输入框的测试、交叉输入框的测试 4.对于删除、修改等&#xff0c;要考虑你…

智慧采购管理系统电子招投标优势浅析,助力建筑工程企业高效做好采购管理工作

随着建筑工程行业的蓬勃发展&#xff0c;竞争也日益激烈。在项目执行过程中&#xff0c;从项目前期投标开始&#xff0c;到项目立项、施工过程、竣工结束的整个过程中&#xff0c;采购活动频繁&#xff0c;且采购类型较多&#xff0c;各项采购金额巨大&#xff0c;如何应用电子…

RK3568平台开发系列讲解(音视频篇)如何把音视频流进行网络传输?

🚀返回专栏总目录 文章目录 一、什么是RTP二、RTP 协议详解三、RTCP 协议详解沉淀、分享、成长,让自己和他人都能有所收获!😄 📢如何将码流打包成一个个数据包发送到网络上,那么我们就需要来了解一下 RTP 和 RTCP 协议。 一、什么是RTP 为了保证传输的实时性,一般使…

[附源码]Python计算机毕业设计Django图书馆出版物预订系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

[附源码]计算机毕业设计基于Springboot影院管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

三款免费的AI绘画网站对比分析,真正好用的居然是它

AI绘画做为人人必装的装机工具。火热之程度就不必要多说了。如果什么是AI绘画&#xff0c;你还不懂的话&#xff0c;只能说自已OUT了。但大家会发现一个很怪的问题。AI绘画清一色没有免费的。连BAT就算有AI绘画产品也不会免费给你用。这是什么原因。 我简单点来讲&#xff0c;…

【100个 Unity实用技能】| 关于触发器互相检测的必要前提条件配置

Unity 小科普 老规矩&#xff0c;先介绍一下 Unity 的科普小知识&#xff1a; Unity是 实时3D互动内容创作和运营平台 。包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者&#xff0c;借助 Unity 将创意变成现实。Unity 平台提供一整套完善的软件解决方案&#xff…

C语言基础5:操作符详解:算术、移位、赋值、单目、关系、逻辑、条件、逗号表达式、下标引用、表达式求值

文章目录C语言基础5&#xff1a;操作符详解&#xff1a;算术、移位、赋值、单目、关系、逻辑、条件、逗号表达式、下标引用、表达式求值1. 算术操作符2. 移位操作符2.1 左移操作符2.2 右移操作符3. 位操作符3.1 位操作符基本介绍3.2 不使用其他变量&#xff0c;交换int 变量的值…

# maven-高级

1:maven技术 1.1 传统项目管理分析(导入jar包形式) .jar包不统一,jar包不兼容 .工程上线维护操作繁琐等 1.2maven组成部分 maven本身是一个项目管理工具&#xff0c;将项目开发和管理抽象成一个项目对象模型&#xff08;POM&#xff09;POM (project object model) : 项目对…

Bug系列路径规划算法原理介绍(三)——Tangent BUG算法

本系列文章主要对Bug类路径规划算法的原理进行介绍&#xff0c;在本系列的第一篇文章中按照时间顺序梳理了自1986年至2018年Bug类路径规划算法的发展&#xff0c;整理了13种BUG系列中的典型算法&#xff0c;从本系列的第二篇文章开始依次详细介绍了其中具有代表性的BUG1、BUG2、…