Contest2850 - 【在线编程平台】2022年计算机类数据结构作业12.20221201-1206
创始人
2024-03-20 23:07:46
0

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

输出样例 复制

43251729#356754476288
#include
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;jdata<lchild==NULL&&tree->rchild!=NULL){for(int j=0;jlchild,i);print(tree->rchild,i);if(tree->lchild!=NULL&&tree->rchild==NULL){for(int j=0;j>n;int a[505];Tree tree;tree=new Node;tree=NULL;for(int i=0;i>a[i];}for(int i=0;i

问题 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
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.named.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

问题 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
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;jdata;if(tree->lchild==NULL&&tree->rchild==NULL)cout<<"("<<0<<")"<lchild==NULL&&tree->rchild!=NULL)cout<<"("<rchild->height*-1<<")"<lchild!=NULL&&tree->rchild==NULL)cout<<"("<lchild->height<<")"<lchild->height-tree->rchild->height<<")"<lchild==NULL&&tree->rchild!=NULL){for(int j=0;jlchild,i);print(tree->rchild,i);if(tree->lchild!=NULL&&tree->rchild==NULL){for(int j=0;j>n;int a[505];Tree tree;tree=new Node;tree=NULL;for(int i=0;i>a[i];}for(int i=0;i

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

题目描述

  给定大小为N(0

输入格式

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

输出格式

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

输入样例 复制

5
1 2 4 4 5 
4

输出样例 复制

3
#include
using namespace std;
int a[1005];int main()
{int n;cin>>n;int t;for(int i=0;i>a[i];}cin>>t;for(int i=0;i

问题 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
using namespace std;
int a[10005];
int b[10005];int main()
{int n;int index=0;cin>>n;for(int i=0;i>a[i];for(int i=0;i>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<

 

 

 

 

 

 

 

 

相关内容

热门资讯

新华鲜报丨利好跨国公司!这项跨... 新华社北京12月26日电(记者刘开雄、吴雨)中国人民银行、国家外汇管理局12月26日发布通知,在总结...
日元空头共识渐成:2026年或... 随着日本央行最新加息举措未能提振汇率,华尔街对日元的看空情绪再度升温,市场正逐渐形成日元将长期疲软的...
北平锋:民进党当局对所谓“两岸... 12月26日,台湾《中国时报》报道,陆委会近日推动所谓“两岸人民关系条例”四项修正,包含:公务员赴陆...
AI核心产业超万亿,工信部将完... 今年,工业经济顶压前行、向新向优发展,展现强大韧性和活力。 12月25日至26日,全国工业和信息化工...
神州泰岳(300002)披露全... 截至2025年12月26日收盘,神州泰岳(300002)报收于11.37元,较前一交易日上涨0.09...
车企起诉电池企业第一案!吉利旗... 出品 | 搜狐汽车·汽车咖啡馆 作者 | 胡耀丹 2024年底发出的回旋镖,在2025年底向欣旺达疾...
海南产经新观察:封关政策释红利... 中新网海南东方12月26日电 (陈英清)“海南自贸港封关运作顺利实施,政策红利持续释放,南繁水稻制种...
无证售药、两地维权!养生馆纠纷... 一副自制中药制剂,引发两地法院诉讼;一次耐心调解,让双方握手言和。近日,饶平县人民法院调解一宗因养生...
*ST节能(000820)披露... 截至2025年12月26日收盘,*ST节能(000820)报收于3.36元,较前一交易日上涨0.9%...
疑电芯质量存问题,500亿巨头... 二线电池厂商欣旺达(300207.SZ)被起诉了! 12月26日盘后,欣旺达披露公告称,公司子公司欣...