DS内排—2-路归并排序

2023-11-09

目录

题目描述

AC代码


题目描述

输入一组字符串,用2-路归并排序按字典顺序进行降序排序。

输入

测试次数t

每组测试数据:数据个数n,后跟n个字符串,字符串不含空格。

输出

对每组测试数据,输出2-路归并排序的每一趟排序结果。每组测试数据的输出之间有1空行。

输入样例1 

2
6 shenzhen beijing guangzhou futian nanshan baoan
10 apple pear peach grape cherry dew fig haw lemon marc

输出样例1

shenzhen beijing guangzhou futian nanshan baoan
shenzhen guangzhou futian beijing nanshan baoan
shenzhen nanshan guangzhou futian beijing baoan

pear apple peach grape dew cherry haw fig marc lemon
pear peach grape apple haw fig dew cherry marc lemon
pear peach haw grape fig dew cherry apple marc lemon
pear peach marc lemon haw grape fig dew cherry apple

AC代码

#include<iostream>
using namespace std;
string origin[256],done[256];
void Merge(int low,int mid,int high){
    int i=low,j=mid+1,k=low;
    while(i<=mid&&j<=high){
        if(origin[i]>=origin[j])
            done[k++]=origin[i++];
        else
            done[k++]=origin[j++];
    }
    while(i<=mid)
        done[k++]=origin[i++];
    while(j<=high)
        done[k++]=origin[j++];
}
int main() {
    int t,n,low,high,step,mid;
    cin>>t;
    while(t--){
        cin>>n;
        for(int i=0;i<n;i++)
            cin>>origin[i];
        for(step=1;step<n;step*=2){
            for(low=0;low<n;low+=2*step){
                mid=low+step-1;
                if(mid>n)
                    break;
                high=low+2*step-1;
                if(high>=n)
                    high=n-1;
                Merge(low,mid,high);
            }
            for(int i=0;i<n;i++)
                origin[i]=done[i];
            for(int i=0;i<n-1;i++)
                cout<<done[i]<<' ';
            cout<<done[n-1]<<endl;
        }
        cout<<endl;
    }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

DS内排—2-路归并排序 的相关文章

随机推荐

  • 数据结构 顺序表的定义

    文章目录 1 2 1 顺序表的定义 1 2 2 顺序表上基本操作的实现 1 顺序表的建立 2 顺序表元素的插入 3 顺序表元素的删除 4 顺序表的查找 1 2 1 顺序表的定义 定义 顺序表是用一组地址连续的存储单元依次存储线性表中的数据元
  • flutter滚动到底部_flutter ScrollController如何滚动到底部?

    flutter ScrollController滚动到底部的示例代码如下 方式一 import package flutter scheduler dart import package flutter material dart void
  • 微信小程序开发全流程记录(从前台到后台,到发布)

    微信小程序开发流程记录 一 代码处理 一 微信小程序 前端显示 微信小程序项目的架构 部分特点说明 二 后台服务器 数据交互 需要的环境 特别注意 二 项目部署 一 Wampserver的设置 二 域名的获取 三 小程序官方网站上的设置 一
  • 阿里大数据之路:数据模型篇大总结

    第1章 大数据领域建模综 1 1 为什么需要数据建模 有结构地分类组织和存储是我们面临的一个挑战 数据模型强调从业务 数据存取和使用角度合理存储数据 数据模型方法 以便在性能 成本 效率之间取得最佳平衡 成本 良好的数据模型能极大地减少不必
  • Linux添加yum源,yum下载速度过慢

    CentOS系统更换yum软件安装源 此处以网易为例 第一步 备份你的原镜像文件 以免出错后可以恢复 mv etc yum repos d CentOS Base repo etc yum repos d CentOS Base repo
  • 英伟达新方法入选CVPR 2023:对未知物体的6D姿态追踪和三维重建

    普通手机 随手 拍的雕像 一下就变成了精细的三维重建图 水杯来回动的动态场景下 细节清晰可见 静态场景效果也同样nice 狗狗突出的肋骨都被还原了出来 对比来看其他方法 效果是酱婶的 这就是英伟达最新提出的方法BundleSDF 这是一种可
  • 什么是JVM

    什么是JVM JVM 内存结构 虚拟机的前世今生 从虚拟机的发展到未来的技术发展 未来的Java技术 JVM整体介绍 JVM各版本内存区域的变化 直接内存 深入分析栈和堆 JVM中的对象 JVM中对象的分配 Java中的泛型 垃圾回收算法与
  • PHP发送邮件详细说明

    这两天琢磨了php得原生发送邮件 发现自带得mail方法不太好用 于是上网查询了好多方法 亲测以下方法能用 源代码都在 我的github 到github上下载 https github com PHPMailer PHPMailer htt
  • 2021年“泰迪杯”数据分析技能赛B 题+肥料登记数据分析数据集

    2021 年 泰迪杯 数据分析技能赛 B 题 肥料登记数据分析 一 背景 肥料是农业生产中一种重要的生产资料 其生产销售必须遵循 肥料登记管 理办法 依法在农业行政管理部门进行登记 各省 自治区 直辖市人民政府 农业行政主管部门主要负责本行
  • vue-$nextTick使用详解

    在vue应用中 我们会碰到 nextTick这个东西 偶尔也会使用 多半是与DOM加载相关 不知道 nextTick为何物 这里搜寻了下资料 做一下总结 nextTick说明 在下次Dom更新循环结束之后执行延迟回调 就是说此次数据变化 在
  • Python自学笔记3-数据类型

    Pytho的数值类型包括 name purpose int 整型 long 长整型 Python3中没有 float 浮点数 complex 复数 代码示例 x 3 整数 f 3 141529 浮点数 name Python 字符串 big
  • 【适合一战成硕的你】考研408笔记(计算机网络)王道+天勤(你再也不用做笔记了)拿捏408.

    考研408笔记系列 提示 点击下面的超链接可以直接到达自己想要的专栏 45分 考研408笔记 数据结构 王道 天勤 45分 考研408笔记 计算机组成原理 王道 天勤 35分 考研408笔记 操作系统 王道 天勤 25分 考研408笔记 计
  • Kali下安装 dvwa 的完整详细教程

    kali之DVWA DVWA共有十个模块 分别是 1 Brute Force 暴力 破解 2 Command Injection 命令行注入 3 CSRF 跨站请求伪造 4 File Inclusion 文件包含 5 File Upload
  • 常用的Dos命令与打开cmd的方式

    打开CMD的方式 开始 系统 命令提示符 Win键 R 输入cmd 打开控制台 推荐 在任意的文件夹下面 按住shift键 鼠标右键点击 在此打开命令行窗口 资源管理器的地址栏前面加上cmd 空格 路径 选择以管理员方式运行 常用的Dos命
  • 符合ISO26262标准的建模规范检查模型静态分析静态测试工具

    符合ISO26262标准的建模规范检查模型静态分析静态测试工具 Model Examiner 功能安全解决方案 以下简称MXAM 测试套件是您进行全面静态模型分析的首选工具 MXAM提供了一种简单的方法来检查建模规范 分析模型结构和评估模型
  • GB2312码表

    转载https blog csdn net oshan2012 article details 79070705
  • 【实践】第一个驱动之自动生成主设备号和设备文件

    1 声明两个变量 static struct class firstdrv class static struct class device firstdrv class dev 2 修改函数first drv init void 和fir
  • 解决同时安装搜狗输入法和谷歌输入法后fcitx无法使用

    问题描述 使用搜狗输入法发现老是出现乱码的问题 然后会提示你删除一个搜狗的文件后重启才能正常使用 因此本人后来听了实验室师兄的建议 又直接安装了谷歌输入法 结果刚开始用着正常 后来突然用着界面右上角的fcitx标志直接消失了 输入法也用不了
  • 【Pytorch】卷积神经网络实现手写数字识别

    Pytorch 卷积神经网络实现手写数字识别 1 加载数据 2 模型构建 3 训练模型 4 模型保存 5 模型加载和使用 1 加载数据 分别构建训练集和测试集 验证集 DataLoader来迭代取数据 import torch import
  • DS内排—2-路归并排序

    目录 题目描述 AC代码 题目描述 输入一组字符串 用2 路归并排序按字典顺序进行降序排序 输入 测试次数t 每组测试数据 数据个数n 后跟n个字符串 字符串不含空格 输出 对每组测试数据 输出2 路归并排序的每一趟排序结果 每组测试数据的