PTA数据结构与算法题目集(中文)  7-37 模拟EXCEL排序 (25 分)

7-37 模拟EXCEL排序 (25 分)
 

Excel可以对一组纪录按任意指定列排序。现请编写程序实现类似功能。

输入格式:

输入的第一行包含两个正整数N(≤) 和C,其中N是纪录的条数,C是指定排序的列号。之后有 N行,每行包含一条学生纪录。每条学生纪录由学号(6位数字,保证没有重复的学号)、姓名(不超过8位且不包含空格的字符串)、成绩([0, 100]内的整数)组成,相邻属性用1个空格隔开。

输出格式:

在N行中输出按要求排序后的结果,即:当C=1时,按学号递增排序;当C=2时,按姓名的非递减字典序排序;当C=3时,按成绩的非递减排序。当若干学生具有相同姓名或者相同成绩时,则按他们的学号递增排序。

输入样例:

3 1
000007 James 85
000010 Amy 90
000001 Zoe 60

输出样例:

000001 Zoe 60
000007 James 85
000010 Amy 90

题目分析:这道题是利用表排序和排序算法的一道题 排序算法采用快排 但最后有两组数据没通过 查了资料用c++STL中的sort就可以 STL中sort函数不单单使用了快排 而且使用了插入排序和堆排序
 #define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<malloc.h> struct Student
{
int Id;
char Name[];
int Score;
}students[];
int Table[];
void Swap(int i, int j)
{
int tmp = Table[i];
Table[i] = Table[j];
Table[j] = tmp;
}
void Quick_Sort_1(int start,int end)
{
if (start >= end - )
return;
int tmp = (start + end) / ;
//三元取中值
if (students[Table[start]].Id > students[Table[end - ]].Id)
Swap(start, end - );
if (students[Table[start]].Id > students[Table[tmp]].Id)
Swap(start, tmp);
if (students[Table[tmp]].Id > students[Table[end - ]].Id)
Swap(tmp, end - );
Swap(start, tmp);
int i = start + ;
for (int j = start+; j < end; j++)
{
if (students[Table[j]].Id < students[Table[start]].Id)
Swap(i++, j);
}
Swap(start,i-);
Quick_Sort_1(start, i-);
Quick_Sort_1(i, end);
}
void Quick_Sort_2(int start, int end)
{
if (start >= end - )
return;
int tmp = (start + end) / ;
if (strcmp(students[Table[start]].Name, students[Table[end-]].Name)<)
Swap(start, end - );
if (strcmp(students[Table[start]].Name, students[Table[tmp]].Name) < )
Swap(start, tmp);
if (strcmp(students[Table[tmp]].Name, students[Table[end-]].Name) < )
Swap(tmp, end - );
Swap(start, tmp);
int i = start + ;
for (int j = start + ; j < end; i++)
{
if (strcmp(students[Table[j]].Name, students[Table[start]].Name) < )
Swap(i++, j);
else if (!strcmp(students[Table[j]].Name, students[Table[start]].Name))
if (students[Table[j]].Id < students[Table[start]].Id)
Swap(i++, j);
}
Swap(start, i - );
Quick_Sort_2(start, i - );
Quick_Sort_2(i, end);
} void Quick_Sort_3(int start, int end)
{
if (start >= end - )
return;
int tmp = (start + end) / ;
if (students[Table[start]].Score > students[Table[end - ]].Score)
Swap(start, end - );
if (students[Table[start]].Score > students[Table[tmp]].Score)
Swap(start, tmp);
if (students[Table[tmp]].Score > students[Table[end - ]].Score)
Swap(tmp, end - );
Swap(start, tmp);
int i = start + ;
for (int j = start + ; j < end; j++)
{
if (students[Table[j]].Score < students[Table[start]].Score)
Swap(i++, j);
else if (students[Table[j]].Score == students[Table[start]].Score)
if (students[Table[j]].Id < students[Table[start]].Id)
Swap(i++, j);
}
Swap(start, i - );
Quick_Sort_3(start, i - );
Quick_Sort_3(i, end);
}
int main()
{
int N,C;
scanf("%d%d", &N,&C);
int id=, score=;
char name[] = { };
for (int i = ; i < N; i++)
{
Table[i] = i;
scanf("%d%s%d", &id, name, &score);
students[i].Id = id;
strcpy(students[i].Name, name);
students[i].Score = score;
}
switch (C)
{
case :Quick_Sort_1(, N); break;
case :Quick_Sort_2(, N); break;
case :Quick_Sort_3(, N); break;
}
for (int i = ; i < N; i++)
printf("%06d %s %d\n", students[Table[i]].Id,students[Table[i]].Name,students[Table[i]].Score);
return ;
}

PTA数据结构与算法题目集(中文) 7-37 模拟EXCEL排序 (25 分)的更多相关文章

  1. PTA数据结构与算法题目集(中文) 7-34

    PTA数据结构与算法题目集(中文)  7-34 7-34 任务调度的合理性 (25 分)   假定一个工程项目由一组子任务构成,子任务之间有的可以并行执行,有的必须在完成了其它一些子任务后才能执行.“ ...

  2. PTA数据结构与算法题目集(中文) 7-31

    PTA数据结构与算法题目集(中文)  7-31 7-31 笛卡尔树 (25 分)   笛卡尔树是一种特殊的二叉树,其结点包含两个关键字K1和K2.首先笛卡尔树是关于K1的二叉搜索树,即结点左子树的所有 ...

  3. PTA数据结构与算法题目集(中文) 7-26

    PTA数据结构与算法题目集(中文)  7-26 7-26 Windows消息队列 (25 分)   消息队列是Windows系统的基础.对于每个进程,系统维护一个消息队列.如果在进程中有特定事件发生, ...

  4. PTA数据结构与算法题目集(中文) 7-14

    PTA数据结构与算法题目集(中文)  7-14 7-14 电话聊天狂人 (25 分)   给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤),为通话记录 ...

  5. PTA数据结构与算法题目集(中文) 7-33

    PTA数据结构与算法题目集(中文)  7-33 7-33 地下迷宫探索 (30 分)   地道战是在抗日战争时期,在华北平原上抗日军民利用地道打击日本侵略者的作战方式.地道网是房连房.街连街.村连村的 ...

  6. PTA数据结构与算法题目集(中文) 7-16

    PTA数据结构与算法题目集(中文)  7-16 7-16 一元多项式求导 (20 分)   设计函数求一元多项式的导数. 输入格式: 以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000 ...

  7. PTA数据结构与算法题目集(中文) 7-10

    PTA数据结构与算法题目集(中文)  7-10 7-10 公路村村通 (30 分)   现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低 ...

  8. PTA数据结构与算法题目集(中文) 7-43字符串关键字的散列映射 (25 分)

    PTA数据结构与算法题目集(中文)  7-43字符串关键字的散列映射 (25 分) 7-43 字符串关键字的散列映射 (25 分)   给定一系列由大写英文字母组成的字符串关键字和素数P,用移位法定义 ...

  9. PTA数据结构与算法题目集(中文) 7-42整型关键字的散列映射 (25 分)

    PTA数据结构与算法题目集(中文)  7-42整型关键字的散列映射 (25 分) 7-42 整型关键字的散列映射 (25 分)   给定一系列整型关键字和素数P,用除留余数法定义的散列函数将关键字映射 ...

  10. PTA数据结构与算法题目集(中文) 7-41PAT排名汇总 (25 分)

    PTA数据结构与算法题目集(中文)  7-41PAT排名汇总 (25 分) 7-41 PAT排名汇总 (25 分)   计算机程序设计能力考试(Programming Ability Test,简称P ...

随机推荐

  1. idea创建django项目

    1.环境.版本 os:windows10 ide:idea python:2.7 django:1.11.25 其他的python.django不确定这么弄会不会有其他问题. 2.python 官网下 ...

  2. 什么是FHS,Linux的文件系统目录标准是怎样的

    Filesystem Hierarchy Standard(文件系统目录标准)的缩写,多数Linux版本采用这种文件组织形式,类似于Windows操作系统中c盘的文件目录,FHS采用树形结构组织文件. ...

  3. 单片机基础——使用GPIO扫描检测按键

    1. 准备工作 硬件准备 开发板首先需要准备一个小熊派IoT开发板,并通过USB线与电脑连接. 软件准备 需要安装好Keil - MDK及芯片对应的包,以便编译和下载生成的代码,可参考MDK安装教程 ...

  4. 痞子衡嵌入式:恩智浦SDK驱动代码风格、模板、检查工具

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家讲的是恩智浦 SDK 驱动的代码风格. 上周痞子衡受领导指示,给 SE 同事做了一个关于 SDK 代码风格的分享.随着组内新人的增多,这样的培训 ...

  5. 爬虫过程中获取不到列表页的url

    例1: 采集某网站的时候根据网页页面显示的url链接提取的, 最后始终没有数据返回. 主要原因是页面源码中标签的 href 属性值和页面上的不一样. 页面上显示是‘http://www.xxx.org ...

  6. frida(hook工具)的环境搭建

    一.简介 frida 是一款基于 python+javascript 的 hook 框架,可运行在 android.ios.linux.win等各个平台,主要使用的动态二进制插桩技术. Frida官网 ...

  7. PDIUSBD12指令

    PDIUSBD12指令 端点描述 PDIUSBD12的端点适用于不同类型的设备,端点可通过[Set mode]命令配置为4种不同的模式,分别为: 模式0(NON-ISO模式):非同步模式 模式1(IS ...

  8. 使用Servlet和JSp在浏览器上实现对数据库表的增删改查(新手)

    第一步:用户输入网址进入一个登陆界面. 里面要有账号密码输入. 登陆界面链接到登陆的Servlet类中. Servlet类 --> 1.接收参数(账户密码)  2.调用DAO层的 SQL语句 验 ...

  9. scrapy爬虫提取网页链接的两种方法以及构造HtmlResponse对象的方式

    Response对象的几点说明: Response对象用来描述一个HTTP响应,Response只是一个基类,根据相应的不同有如下子类: TextResponse,HtmlResponse,XmlRe ...

  10. 原来rollup这么简单之 rollup.watch篇

    大家好,我是小雨小雨,致力于分享有趣的.实用的技术文章. 内容分为翻译和原创,如果有问题,欢迎随时评论或私信,希望和大家一起进步. 大家的支持是我创作的动力. 计划 rollup系列打算一章一章的放出 ...