正文之前

今天去牛客网试了试一些实战编程题,感觉贼有意思,但是也很难,挑了个成绩排序的算法题我就开始怼!

对我一个编程经验并不是很丰富的人来说,确实算是个挑战了。

所以我满满当当的搞了四个小时多,才算是把牛客的这个题目给解答了。而且还是残缺版本,因为我没用指针,所以估计时间或者是内存抄了。最后牛客给我的回答是我的不合格 ~~~~心痛!! (╯‵□′)╯︵┻━┻

正文

以后我的正文尽力简洁(好吧,我承认是我懒得打字了。所以就直接发代码吖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++版本的更多相关文章

  1. 【我的漫漫跨考路】数据结构之单链表线性存储实现 Beta

    正文之前 昨天晚上阶段性的完成了一部分数学的复习,所以今天打算撸一撸代码,然后发现提电脑忘指针.所以自己磕磕盼盼,对照了一下网上的代码,总算把线性存储单链表的数据类型实现,给自己写出来了. 废话不多说 ...

  2. 【二】调通单机版的thrift-C++版本

    [任务2]调通单机版的thrift-C++版本 [任务2]调通单机版的thrift-C++版本 创建文件 安装boost开发工具 拷贝文件 [可忽略此步骤,如果c++代码直接编译无误的话] 编译 创建 ...

  3. 解Bug之路-TCP粘包Bug

    解Bug之路-TCP粘包Bug - 无毁的湖光-Al的个人空间 - 开源中国 https://my.oschina.net/alchemystar/blog/880659 解Bug之路-TCP粘包Bu ...

  4. 【一】调通单机版的thrift-python版本

    开发步骤说明 [任务1]调通单机版的thrift-python版本 [任务1]调通单机版的thrift-python版本 安装thrift 创建thrift模块文件并编译 开发python版的clie ...

  5. 第三篇、调优之路 Apache调优

    1.  简介 在第一篇中整合了apache + tomcat ,利用了apache解析静态文件为tomcat解压.但是在测试机上发现两者性能不足,不能充分利用服务器的性能,该篇中将对apache进行性 ...

  6. STM32 一个定时器产生4路 独立调频率,占中比可调,脉冲个数可以统计。

    实现这个功能,基本原理是利用STM32 的输出比较功能. 1.其它设置就是普通定时器的设置这里开启,四个输出比较中断,和一个更新中断, 更新中断这里不需要开也可以达到目的,我这里开启是做其它的用处的. ...

  7. 【centOS7】Jenkins安装--漫漫踩坑路

    安装步骤: https://www.cnblogs.com/h--d/p/5673085.html 安装后遇到的问题及解决办法: jenkins的admin用户的初始密码路径 https://blog ...

  8. 发现护考上机考试的一个bug:附软件截图(模拟软件)

    目录: 一.文章主旨 二.问题发现的起因 三.bug(问题)描述 四.软件截图 五.我的思考 六.一点期盼 一.文章主旨: 2019年5月18.19.20日,又是一年一度的护资考试(上机考),考试前夕 ...

  9. [转] Chrome - 浏览器跨域访问设置(附:新老版本两种设置方法)

    [From] http://www.hangge.com/blog/cache/detail_1703.html 在进行前后分离的 webapp 开发,或者 H5 移动 App 开发时,我们会使用 P ...

随机推荐

  1. 如何解决苹果Mac系统无法识别U盘

       1.在Mac机上打开“磁盘工具”,将U盘重新分区, 2.格式选“exFAT”.该格式分区Win及Mac系统中都可以读和写,特别是可以支持大于4GB的大文件.但是一些高清播放机可能不支持. 3.以 ...

  2. Example013操作样式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. JavaScript学习笔记(散)——继承、构造函数super

    构造函数中的super 今天看<JavaScript设计模式与开发实践>时,在书中看到一段代码出现super语句,第一次看到这个关键字,所以上网查了下它的作用,发现这个关键字是来自java ...

  4. winform .net2.0的程序如何运行于.net 4.x

    约束 最近有一个winform项目,要求: (1)程序能够运行在winxp, win7, win8, win10中 (2)安装尽可能简单,尽量不要安装.net framework.即使要安装也要尽可以 ...

  5. H3CNE实验:通过Console端口本地访问H3C设备

    连接好Console线后,将交换机开机,在SecureCRT上会显示如下信息: Starting...... RAMLine.....OK System is booting............. ...

  6. MyBatis源码解析【4】反射和动态代理

    通过之前的介绍,我们了解了几个组件的生命周期. 它也是我们重要装备之一. 今天我们需要搞一件更加强的装备,叫做反射和动态代理. 如果没有这件装备的话,显然后面的源码boss是打不动的. 顺便说一下,下 ...

  7. 学会git玩转github,结尾有惊喜!有惊喜!有惊喜!

    一.什么是Github Github是全球最大的社交编程及代码托管网站(https://github.com/). Github可以托管各种git库,并提供一个web界面(用户名.github.io/ ...

  8. 开发servlet三种方式

    第一种:实现Servlet接口 ServletDemo类 实现Servlet接口 public class ServletDemo implements Servlet { //初始化该servlet ...

  9. 浅谈javascript中的call与apply方法

    call方法与apply方法都是为了改变函数体内部this的指向. call方法与apply方法,这二者的作用完全一样,只是接受参数的方式不太一样. apply()方法: Function.apply ...

  10. windows环境下,anoconnda安装tensorflow

    最近对深度学习研究比较多,目前最火的Python深度学习库应该是tensorflow了. 为了方便,本人在windows下用anaconda来使用python,且同时安装了,anaconda2,3,3 ...