【我的漫漫跨考路】有生之年·调完了BUG--冒泡排序C++版本

正文之前
今天去牛客网试了试一些实战编程题,感觉贼有意思,但是也很难,挑了个成绩排序的算法题我就开始怼!
对我一个编程经验并不是很丰富的人来说,确实算是个挑战了。
所以我满满当当的搞了四个小时多,才算是把牛客的这个题目给解答了。而且还是残缺版本,因为我没用指针,所以估计时间或者是内存抄了。最后牛客给我的回答是我的不合格 ~~~~心痛!! (╯‵□′)╯︵┻━┻

正文
以后我的正文尽力简洁(好吧,我承认是我懒得打字了。所以就直接发代码吖a~~~~)
题目描述
查找和排序
- 题目:输入任意(用户,成绩)序列,可以获得成绩从高到低或从低到高的排列,相同成绩都按先录入排列在前的规则处理。
- 例示:
jack 70
peter 96
Tom 70
smith 67
- 从高到低 成绩
peter 96
jack 70
Tom 70
smith 67
- 从低到高
smith 67
Tom 70
jack 70
peter 96
- 输入描述:
输入多行,先输入要排序的人的个数,然后输入排序方法0(降序)或者1(升序)再分别输入他们的名字和成绩,以一个空格隔开 - 输出描述:
按照指定方式输出名字和成绩,名字和成绩之间以一个空格隔开 - 示例1
- 输入、输出
3
0
fang 90
yang 50
ning 70
fang 90
ning 70
yang 50
代码:
#include <iostream>
#include <cstring>
using namespace std;
void sort(string a[], int b[], int n, int rule);
int main()
{
int number,rule,i;
string a[100];
int b[100];
cout<<"input the number you want to sort and the rules:(0 down,1 up)"<<"\n";
cin>>number>>rule;
cout<<"\nplease input the (name score) array: \n";
for(i=0;i<number;++i)
{
cin>>a[i]>>b[i];
cout<<"\n";
}
cout<<"Begin~"<<"\n";
sort(a,b, number, rule);
return 0;
}
void sort(string a[], int b[], int n, int rule)
{
string SortedArrayA[100];
for (int i = 0; i < n; ++i)
{
SortedArrayA[i]=a[i];
}
int SortedArrayB[100];
for (int i = 0; i < n; ++i)
{
SortedArrayB[i]=b[i];
}
string name;
int score;
int j;
int i;
for(j=n; j > 0; --j)
{
for(i=0;i<j-1;++i)
{
if(SortedArrayB[i]>SortedArrayB[i+1])
{
name=SortedArrayA[i];
score=SortedArrayB[i];
SortedArrayA[i]=SortedArrayA[i+1];
SortedArrayB[i]=SortedArrayB[i+1];
SortedArrayB[i+1]=score;
SortedArrayA[i+1]=name;
}
}
}
switch(rule)
{
case 0:
for (int i = n-1; i >=0; --i)
{
cout<<SortedArrayA[i]<<" "<<SortedArrayB[i]<<"\n";
cout<<"\n";
};
break;
case 1:
for (int k = 0; k < n; ++k)
{
cout<<SortedArrayA[k]<<" "<<SortedArrayB[k]<<"\n";
cout<<"\n";
};
break;
default:
cout<<"sorry";
break;
}
cout<<"done"<<endl;
system("pause");
}
运行结果:

正文之后
“没错,你已经看完了。”
“啊哈?没有代码注释?那你写个啥?”
“啊?代码注释?那是个啥?我赶时间,自行领悟呀,我赶时间!
此中有真意~~~欲辨已忘言····”
忍不住还是秀一下我的工作界面,爽歪歪~~~

【我的漫漫跨考路】有生之年·调完了BUG--冒泡排序C++版本的更多相关文章
- 【我的漫漫跨考路】数据结构之单链表线性存储实现 Beta
正文之前 昨天晚上阶段性的完成了一部分数学的复习,所以今天打算撸一撸代码,然后发现提电脑忘指针.所以自己磕磕盼盼,对照了一下网上的代码,总算把线性存储单链表的数据类型实现,给自己写出来了. 废话不多说 ...
- 【二】调通单机版的thrift-C++版本
[任务2]调通单机版的thrift-C++版本 [任务2]调通单机版的thrift-C++版本 创建文件 安装boost开发工具 拷贝文件 [可忽略此步骤,如果c++代码直接编译无误的话] 编译 创建 ...
- 解Bug之路-TCP粘包Bug
解Bug之路-TCP粘包Bug - 无毁的湖光-Al的个人空间 - 开源中国 https://my.oschina.net/alchemystar/blog/880659 解Bug之路-TCP粘包Bu ...
- 【一】调通单机版的thrift-python版本
开发步骤说明 [任务1]调通单机版的thrift-python版本 [任务1]调通单机版的thrift-python版本 安装thrift 创建thrift模块文件并编译 开发python版的clie ...
- 第三篇、调优之路 Apache调优
1. 简介 在第一篇中整合了apache + tomcat ,利用了apache解析静态文件为tomcat解压.但是在测试机上发现两者性能不足,不能充分利用服务器的性能,该篇中将对apache进行性 ...
- STM32 一个定时器产生4路 独立调频率,占中比可调,脉冲个数可以统计。
实现这个功能,基本原理是利用STM32 的输出比较功能. 1.其它设置就是普通定时器的设置这里开启,四个输出比较中断,和一个更新中断, 更新中断这里不需要开也可以达到目的,我这里开启是做其它的用处的. ...
- 【centOS7】Jenkins安装--漫漫踩坑路
安装步骤: https://www.cnblogs.com/h--d/p/5673085.html 安装后遇到的问题及解决办法: jenkins的admin用户的初始密码路径 https://blog ...
- 发现护考上机考试的一个bug:附软件截图(模拟软件)
目录: 一.文章主旨 二.问题发现的起因 三.bug(问题)描述 四.软件截图 五.我的思考 六.一点期盼 一.文章主旨: 2019年5月18.19.20日,又是一年一度的护资考试(上机考),考试前夕 ...
- [转] Chrome - 浏览器跨域访问设置(附:新老版本两种设置方法)
[From] http://www.hangge.com/blog/cache/detail_1703.html 在进行前后分离的 webapp 开发,或者 H5 移动 App 开发时,我们会使用 P ...
随机推荐
- Linux下重启多个 tomcat 服务的脚本
由于修改tomcat的配置文件或手动操作数据库数据后,tomcat的缓存和redis的缓存很严重,需要经常重启tomcat来释放缓存,经常就是手动重启. # .查找tomcat的进程ID ps -ef ...
- CentOS yum 安装 PHP 5.6.24
配置yum源 追加CentOS 6.5的epel及remi源. # rpm -Uvh http://ftp.iij.ad.jp/pub/linux/fedora/epel/6/x86_64/epel- ...
- 手把手教你 基础 整合最优雅SSM框架:SpringMVC + Spring
我们看招聘信息的时候,经常会看到这一点,需要具备SSH框架的技能:而且在大部分教学课堂中,也会把SSH作为最核心的教学内容. 但是,我们在实际应用中发现,SpringMVC可以完全替代Struts,配 ...
- 怎么用VBS脚本自动注册yy娱乐的账号
set WshShell=WScript.CreateObject("WScript.Shell") Const user = "hugetech2" Cons ...
- css 背景图片自适应
body{ height:100%; overflow:hidden;} .bg { background-image: url(../../img/beijing.jpg); width:100%; ...
- 【转】Header Only Library的介绍
什么是Header Only Library Header Only Library把一个库的内容完全写在头文件中,不带任何cpp文件. 这是一个巧合,决不是C++的原始设计. 第一次这么做估计是ST ...
- PeopleCode事件和方法只用于online界面不能用于组件接口(component interface)
在使用CI过程中,哪些方法是不能使用的.以下为PeopleBook解释的内容. 一.搜索框代码不执行:SearchInit, SearchSave, and RowSelect events 意味着使 ...
- 修改MySQL数据库密码
在mysql数据库里面有一个默认安装的数据库是mysql,里面有一个user表.里面的字段Host是运行登录的ip地址,User 是登录的账号Password是密码. use mysql;//使用my ...
- HDU 1325,POJ 1308 Is It A Tree
HDU认为1>2,3>2不是树,POJ认为是,而Virtual Judge上引用的是POJ数据这就是唯一的区别....(因为这个瞎折腾了半天) 此题因为是为了熟悉并查集而刷,其实想了下其实 ...
- Android_65535问题的解决
做过比较大的项目的人都知道,当app大到一定程度的时候,会出现65535这个错误,也就是64K,也就是,一个app包中,方法数不能超过65535个,超过了就要分成多个dex包,这个别问为什么,andr ...