Contest2874 - 【在线编程平台】2022年计算机类数据结构作业14.20221215-1220

news2025/6/11 8:43:45

目录

问题 A: 大顶堆还是小顶堆?

问题 B: sort by age

问题 C: 统计字母个数

问题 D: 字母排序

问题 E: 算法10-6~10-8:快速排序


问题 A: 大顶堆还是小顶堆?

内存限制:128 MB时间限制:1.000 S标准输入输出

题目类型:传统评测方式:文本比较

题目描述

一个CPU处理的任务队列,并不总是按照时间顺序处理,有些任务有着更高的优先级。比如:一个任务需要对核反应堆进行调度,另一个任务是打印一个文档。
针对这种需要处理优先级的任务选择执行场景,需要设计一种数据结构,高效率实现以下两种操作,从集合中定位并删除最大值(执行任务),在集合中插入新元素(新增任务)。堆就是这样一种数据结构。

堆是一种完全二叉树:0号节点为根结点,i号的左子为2*i+1,右子为2*i+2。按照内部元素的大小关系,堆可以分为大顶堆和小顶堆两种。
大顶堆(降序堆):每个结点的值都大于或等于其左右孩子结点的值
小顶堆(升序堆):每个结点的值都小于或等于其左右孩子结点的值
可以用数组去实现堆的存储。
本题给出用数组实现的堆包含的所有元素,请判断其是大顶堆,小顶堆,或者不是堆呢?

输入格式

输入第一行为大于等于2且小于100的一个正整数n,代表数组中元素个数
第二行为空格分割的n个正整数,代表数组中的每个元素

输出格式

输出包括一行
如果是大顶堆,输出Big Heap
如果是小顶堆,输出Small Heap
如果不满足堆堆条件,输出Not Heap

输入样例 复制

6
5 16 30 33 15  38

输出样例 复制

Not Heap
#include<bits/stdc++.h>
using namespace std;
int a[1005];
 
int main()
{
    int n;
    cin>>n;
    queue<int>q;
    for(int i=0;i<n;i++)
        cin>>a[i];
    q.push(a[0]);
    int da=0;
    int xiao=0;
    int no=0;
    for(int i=1;i<n;i++)
    {
        q.push(a[i]);
        if(i+1==n)
            q.push(q.front());
        q.push(a[i+1]);
        if(q.front()>=a[i]&&q.front()>=a[i+1])
            da=1;
        else if(q.front()<=a[i]&&q.front()<=a[i+1])
            xiao=1;
        else
            no=1;
        q.pop();
        i++;
    }
    if(no)
    {
        cout<<"Not Heap"<<endl;
        return 0;
    }
    if(da&&!xiao)
    {
        cout<<"Big Heap"<<endl;
        return 0;
    }
    if(!da&&xiao)
    {
        cout<<"Small Heap"<<endl;
        return 0;
    }
    if(da&&xiao)
    {
        cout<<"Not Heap"<<endl;
        return 0;
    }
}

问题 B: sort by age

内存限制:256 MB时间限制:1.000 S标准输入输出

题目类型:传统评测方式:文本比较

提交:4843通过:1653

题目描述

You are given the ages (in years) of all people of a country with at least 1 year of age. You know that no individual in that country lives for 101 or more years. Now, you are given a very simple task of sorting all the ages in ascending order.

输入格式

There are multiple test cases in the input file. Each case starts with an integer (0<n<=2000000), the total number of people. In the next line, there are integers indicating the ages. Input is terminated with a case where = 0. This case should not be processed.

输出格式

For each case, print a line with space separated integers. These integers are the ages of that country sorted in ascending order.

输入样例 复制

5
2 1 4 3 6
3
2 1 3
0

输出样例 复制

1 2 3 4 6
1 2 3
#include<bits/stdc++.h>
using namespace std;
 
 
int main()
{
    int n;
    while(cin>>n)
    {
        int a[105]={0};
        if(n==0)
            return 0;
        int index;
        for(int i=0;i<n;i++)
        {
            cin>>index;
            a[index]++;
        }
        for(int i=1;i<101;i++)
        {
            if(a[i]!=0)
            {
                for(int j=0;j<a[i];j++)
                    cout<<i<<" ";
            }
        }
        cout<<endl;
    }
}

问题 C: 统计字母个数

内存限制:128 MB时间限制:1.000 S标准输入输出

题目类型:传统评测方式:文本比较

提交:2455通过:1262

题目描述

给定一段文章,请输出每个小写字母出现的次数

输入格式

只有一组输入数据,该数据大小<10KB。文章中包含大小写字母、空格和换行符、标点,数字,其他符号等,以’#’结尾。

输出格式

输出格式为“C A”,C为’a’..’z’中的字母,A为出现次数,C和A之间空一格
注意只统计小写字母的数量,忽略其他字符。

输入样例 复制

here is the input
this is the article#

输出样例 复制

a 1
b 0
c 1
d 0
e 5
f 0
g 0
h 4
i 5
j 0
k 0
l 1
m 0
n 1
o 0
p 1
q 0
r 2
s 3
t 5
u 1
v 0
w 0
x 0
y 0
z 0
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
 
ll a[30];
int main()
{
    char c;
    while(cin>>c)
    {
        if(c=='#')
            break;
        if(c>='a'&&c<='z')
            a[int(c)-97]++;
    }
    for(int i=0;i<26;i++)
        cout<<char(i+97)<<" "<<a[i]<<endl;
}

问题 D: 字母排序

内存限制:128 MB时间限制:2.000 S标准输入输出

题目类型:传统评测方式:文本比较

提交:2116通过:982

题目描述

有一天,老师给小明一个字符串,要求小明把这个字符串从小到大排序,但是小明太懒了,你能帮帮他吗?

输入格式

第一行输入一个整数T,共有T组测试数据(T<=100)。
每组输入数据占一行,为一个仅包含小写字母的字符串(长度<=100000)。
 

输出格式

输出有T行,每行包括一个排好序的字符串

输入样例 复制

2
abc
acb

输出样例 复制

abc
abc
#include<bits/stdc++.h>
using namespace std;
 
 
int main()
{
    int t;
    cin>>t;
    while(t--)
    {
        string s;
        int a[30]={0};
        cin>>s;
        int n=s.length();
        for(int i=0;i<n;i++)
            a[int(s[i])-97]++;
        for(int i=0;i<26;i++)
        {
            if(a[i]!=0)
            {
                for(int j=0;j<a[i];j++)
                    cout<<char(i+97);
            }
        }
        cout<<endl;
    }
}

问题 E: 算法10-6~10-8:快速排序

内存限制:128 MB时间限制:1.000 S标准输入输出

题目类型:传统评测方式:文本比较

提交:3181通过:1676

提交

提交C++答案 (提交main.cpp文件)

返回比赛提交记录

题目描述

快速排序是对起泡排序的一种改进。它的基本思想是,通过一趟排序将待排序的记录分割成两个独立的部分,其中一部分记录的关键字均比另一部分的关键字小,在分成两个部分之后则可以分别对这两个部分继续进行排序,从而使整个序列有序。

快速排序的算法可以描述如下:

在本题中,读入一串整数,将其使用以上描述的快速排序的方法从小到大排序,并输出。

输入格式

输入的第一行包含1个正整数n,表示共有n个整数需要参与排序。其中n不超过100000。 第二行包含n个用空格隔开的正整数,表示n个需要排序的整数。

输出格式

只有1行,包含n个整数,表示从小到大排序完毕的所有整数。 请在每个整数后输出一个空格,并请注意行尾输出换行。

输入样例 复制

10
2 8 4 6 1 10 7 3 5 9

输出样例 复制

1 2 3 4 5 6 7 8 9 10 

数据范围与提示

*** 提示已隐藏,点击此处可显示 ***

收起提示[-]

在本题中,需要按照题目描述中的算法完成快速排序的算法。 快速排序是一种十分常用的排序算法,其平均时间复杂度为O(knlnn),其中n为待排序序列中记录的个数,k为常数。大量的实际应用证明,在所有同数量级的此类排序算法中,快速排序的常数因子k是最小的,因此,就平均时间而言,快速排序是目前被认为最好的一种内部排序方法。 而在C语言的常用编译器中,qsort函数是一个非常常用的快速排序函数。

#include<bits/stdc++.h>
using namespace std;
int a[100005];
 
void qs(int l,int r)
{
    if(l<r)
    {
        int i,j,x;
        i=l,j=r,x=a[i];
        while(i<j)
        {
            while(i<j&&a[j]>x)
                j--;
            if(i<j)
                a[i++]=a[j];
            while(i<j&&a[i]<x)
                i++;
            if(i<j)
                a[j--]=a[i];
        }
        a[i]=x;
        qs(l,i-1);
        qs(i+1,r);
    }
}
 
int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
        cin>>a[i];
    qs(0,n-1);
    for(int i=0;i<n;i++)
        cout<<a[i]<<" ";
    cout<<endl;
    return 0;
}

 

 

 

 

 

 

 

 

 

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

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

相关文章

数学建模国赛 2020B-穿越沙漠 第二关至第六关思路分享

穿越沙漠第二关至第六关思路 开始讲题之前唠嗑一下&#xff1a; 很感谢所有读者和粉丝对上一篇的第一关解题博文的喜欢&#xff0c;也收到很多人的称赞&#xff0c;我很高兴大家能喜欢我写的东西。 其实这道题的模型在建立之处就是对着六关通用的目标去写的&#xff0c;因为本…

现货黄金时间表怎么安排?

现货黄金交易时间表&#xff0c;最好每一个投资者打印一份出来&#xff0c;放在你的电脑旁边。为什么呢&#xff1f;以前我对现货黄金交易时间表也没有特别关心&#xff0c;为什么在二十四小时的全天候交易要花时间到这里面来呢&#xff1f; 黄金市场是一个全球性的市场&#x…

APP测试技术:ADB——安卓手机测试一座神奇的“桥”

前言&#xff1a; 近年移动互联网好比IT界的一条浩瀚银河&#xff0c;安卓手机测试可谓其中最璀璨的一颗明珠&#xff0c;这里有一座你不得不熟悉的桥--ADB 曾见过不少相关的文章或培训&#xff0c;不乏空谈多&#xff0c;实战少&#xff1b;期望大&#xff0c;效果差。也见过…

idea上传代码到GitHub,每一步附带注意事项(炒鸡炒鸡详细)

1. idea配置git 2. 在idea里面登录自己的GitHub账号 需要到GitHub生成token 点击后&#xff0c;翻到最底部&#xff0c;点击左侧导航栏的Developer settings&#xff0c;到达下面这张图 最后点击最底部的绿色按钮&#xff0c;然后复制token即可。 3. 在创建本地仓库&#xff0…

【强化学习基础】强化学习的基本概念:状态、动作、智能体、策略、奖励、状态转移

文章目录1.状态&#xff08;State&#xff09;2.动作&#xff08;Action&#xff09;3.智能体&#xff08;Agent&#xff09;4.策略&#xff08;Policy&#xff09;5.奖励&#xff08;Reward&#xff09;6.状态转移&#xff08;State transition&#xff09;7.智能体与环境交互…

生成模型6-重参数技巧

Stochastic Back Propagation &#xff08;Reparametrization Trick&#xff09; 本章主要介绍的是&#xff0c;神经网络用函数逼近器&#xff0c;那么我们将想想神经网络和概率图模型之间有什么关系呢&#xff1f;能不能用NN去逼近一个概率分布呢&#xff1f;把他们两结合到一…

如今的测试行业都怎么了?面试题有必要出这么难吗?

在测试行业摸爬滚打了十年左右的我&#xff0c;时不时会被公司要求去做面试官面试别人。在这段期间我也收到了不少的简历&#xff0c;面试了各种技术不一的人。许多候选人的工作年限都不少&#xff0c;基本都是在3~5年左右&#xff0c;但他们做的都是一些非常传统的项目&#x…

VB知识点-学业水平考试

目录 一、VB中常用的几个基本控件 二、VB工程常识 三、VB常用的基本数据类型​编辑 四、VB常用的标准函数 五、VB的基本运算 六、VB语句 &#xff08;1&#xff09;符号常量定义语句 &#xff08;2&#xff09;变量定义语句 &#xff08;3&#xff09;赋值语句 &…

BAT大厂Python面试题精选,看完后离拿到offer只有一步之遥(含答案)

Python是目前编程领域最受欢迎的语言。在本文中&#xff0c;我将总结华为、阿里巴巴等互联网公司Python面试中最常见的30个问题。每道题都提供参考答案&#xff0c;希望能够帮助你在求职面试中脱颖而出&#xff0c;找到一份高薪工作。这些面试题涉及Python基础知识、Python编程…

AOP注解方式进行增强接口

&#x1f4da;目录&#x1f4da;简介&#xff1a;&#x1f4a8;进阶版&#x1f5fa;️未实现AOP效果&#x1f3a2;创建注解&#xff1a;&#x1f4ad;创建注解切面&#x1f680;使用方式&#xff1a;&#x1f389;结束&#xff1a;&#x1f4da;简介&#xff1a; 需要对AOP有一…

【电商】电商系统---供应商管理

本文以电商系统中的供应商管理为讨论对象&#xff0c;分析了其中的管理、属性、流程等内容&#xff0c;希望能给你带来启发与思考。 前言 前天写了一篇“以商品流转了解系统模块”介绍&#xff0c;里面啰里啰唆的说了很多模块&#xff0c;每个都是系统的组成部分&#xff0c;都…

数字化程度持续推进,元宇宙逐步走向成熟

元宇宙是人类数字化生存的最高形态 根据观研报告网发布的《2022年中国元宇宙行业分析报告-行业现状与发展趋势分析》显示&#xff0c;元宇宙是一个平行于现实世界&#xff0c;又独立于现实世界的虚拟空间&#xff0c;是映射现实世界的在线虚拟世界&#xff0c;是越来越真实的数…

美国访问学者签证材料清单

美国访问学者签证材料清单&#xff1a; 1、有效护照&#xff1a;如果您的护照将在距您预计抵美日期的六个月内过期、或已损坏、或护照上已无空白的签证签发页, 请在前来面谈之前先申请一本新护照。 2、一张照片:于6个月内拍摄的5 X5厘米正方形白色背景的彩色正面照。请将照片用…

【多聚焦图像:GAN:无监督】

MFF-GAN: An unsupervised generative adversarial network with adaptive and gradient joint constraints for multi-focus image fusion &#xff08;MFF-GAN: 具有自适应和梯度联合约束的无监督生成对抗网络&#xff0c;用于多焦点图像融合&#xff09; 从梯度的角度来进行…

【蓝桥杯】第12届Scratch国赛中级组第7题 -- 博士汪出题

[导读]&#xff1a;蓝桥杯大赛是工业和信息化部人才交流中心举办的全国性专业信息技术赛事。蓝桥杯大赛首席专家倪光南院士说&#xff1a;“蓝桥杯以考促学&#xff0c;塑造了领跑全国的人才培养选拨模式&#xff0c;并获得了行业的深度认可。” 春雷课堂计划推出Scratch蓝桥杯…

业务中台的架构案例

业务中台目标 目标&#xff1a; 整体目标&#xff1a;高内聚、低耦合&#xff0c;便于开发和维护。五个方向&#xff1a;性能、可用性、扩展性、伸缩性、安全性。 原因&#xff1a; 单体架构的大泥球会导致业务迭代困难、无法针对性伸缩、故障没有隔离等问题&#xff0c;需要向…

Python核心编程三大神兽——迭代器、生成器 、以及装饰器

装饰器 装饰器概述 装饰器本质&#xff1a;函数闭包的语法糖&#xff0c;一个函数&#xff0c;该函数用来处理其他函数&#xff0c;在不改变源函数的情况下添加功能&#xff0c;装饰器的返回值可以是一个函数对象 使用场景&#xff1a;插入日志&#xff0c;事务处理&#xf…

网心科技入选亿欧《2022年中国边缘计算产业研究报告》

近日,亿欧智库对外发布了《2022年中国边缘计算产业研究报告》,《报告》公布了“边缘计算产业图谱”和“行业新锐:中国边缘计算技术领先企业榜单”两项,网心科技(OneThing)均成功入选,彰显了网心科技在边缘计算领域的技术实力和市场领先地位。 当前,边缘计算与千行百业的深度融合…

51单片机实训day2——创建Keil工程

以管理员身份打开软件&#xff01;&#xff01;&#xff01;以管理员身份打开软件&#xff01;&#xff01;&#xff01;以管理员身份打开软件&#xff01;&#xff01;&#xff01; 内 容&#xff1a;Keil工程创建 学 时&#xff1a;2学时 知识点&#xff1a;开发固件库介绍…

从英语翻译到人工智能:我如何用两年时间跨界转行

在这两年里&#xff0c;我经历了以下大大小小的里程碑&#xff1a; 2016 年初&#xff1a;在德国刚开始读英语语言学硕士没多久&#xff0c;萌生了转方向到计算机语言学&#xff08;Computational Linguistics&#xff0c;后来我才知道那与自然语言处理 Natual Language Proces…