数据结构作业12

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

 code

#include<bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define MAX_SIZE 105
 
struct BSTNode{
    int data;
    BSTNode *leftChild,*rightChild;
};
 
void Insert(BSTNode *&root,int data){
    if(root==NULL){
        BSTNode *t=new BSTNode;
        t->data=data;
        t->leftChild=NULL;
        t->rightChild=NULL;     
        root=t;   
    }
    else{
        if(data < root->data){
            Insert(root->leftChild,data);
        }
        else{
            Insert(root->rightChild,data);
        }
    }
}
 
void Print(BSTNode *&root,int depth){
    for(int i=0;i<depth;i++){
        cout<<"    ";
    }
    if(root==NULL) {
        cout<<"#"<<endl;
    }
    else{
        cout<<root->data<<endl;
        if(root->leftChild==NULL&&root->rightChild==NULL){
            return;
        }
        else{
            Print(root->leftChild,depth+1);
            Print(root->rightChild,depth+1);
        }
    }
}
 
int main(){
    int n;cin>>n;
    BSTNode *root=NULL;
    for(int i=0;i<n;i++){
        int t;cin>>t;
        Insert(root,t);
    }
    Print(root,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

code

我的变量名好像真的闭着眼定义的呜呜

#include<bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define MAX_SIZE 105

struct tt{
    string name;
    int num=0;
    int saleAmount=0;
}sale[100005];

bool cmp(tt a,tt b){
    if(a.num!=b.num)
    return a.num>b.num;
    return a.name<b.name;
}

int main(){
    int index=0;
    int b,c;
    string a,d;
    while(cin>>a>>b>>c>>d){
        int flag=-1;
        for(int i=0;i<index;i++){
            if(sale[i].name==a){
                flag=i;
                break;
            }
        }
        if(flag==-1){
            sale[index].name=a;
            sale[index].num+=b;
            sale[index].saleAmount+=c*b;
            index++;
        }
        else{
            sale[flag].num+=b;
            sale[flag].saleAmount+=c*b;
        }
    }
    sort(sale,sale+index,cmp);
    for(int i=0;i<index;i++){
        cout<<sale[i].name<<" "<<sale[i].num<<" "<<sale[i].saleAmount<<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)

code

#include<bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define MAX_SIZE 105
 
struct BSTNode{
    int data;
    BSTNode *leftChild,*rightChild;
};
 
void Insert(BSTNode* &root,int data){
    if(root==NULL){
        BSTNode *t=new BSTNode;
        t->data=data;
        t->leftChild=NULL;
        t->rightChild=NULL;     
        root=t;   
    }
    else{
        if(data < root->data){
            Insert(root->leftChild,data);
        }
        else{
            Insert(root->rightChild,data);
        }
    }
}
 
int FindDepth(BSTNode* &root){
    if(root==NULL) return 0;
    else{
        return max(FindDepth(root->leftChild)+1,FindDepth(root->rightChild)+1);
    }
}
 
void Print(BSTNode *&root,int depth){
    for(int i=0;i<depth;i++){
        cout<<"    ";
    }
    if(root==NULL) {
        cout<<"#"<<endl;
    }
    else{
        cout<<root->data<<"("<<FindDepth(root->leftChild)-FindDepth(root->rightChild)<<")"<<endl;
        if(root->leftChild==NULL&&root->rightChild==NULL){
            return;
        }
        else{
            Print(root->leftChild,depth+1);
            Print(root->rightChild,depth+1);
        }
    }
}
 
int main(){
    int n;cin>>n;
    BSTNode *root=NULL;
    for(int i=0;i<n;i++){
        int t;cin>>t;
        Insert(root,t);
    }
    Print(root,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

code

等等这题好像水过去的() 

#include<bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define MAX_SIZE 105
 
int main(){
    int n;cin>>n;
    int a[n];
    for(int i=0;i<n;i++){
        cin>>a[i];
    }
    int t;cin>>t;
    sort(a,a+n);
    int i;
    for(i=0;i<n;i++){
        if(a[i]==t) break;
    }
    if(i>=n) cout<<"-1";
    else cout<<i+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

code 

这个是题水不是我水

#include<bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define MAX_SIZE 105
 
int main(){
    int n;cin>>n;
    int a[2*n];
    for(int i=0;i<2*n;i++){
        cin>>a[i];
    }
    sort(a,a+2*n);
    cout<<a[n-1];
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值