一种排序

时间限制:3000 ms | 内存限制:65535 KB
难度:3
 
描述
现在有很多长方形,每一个长方形都有一个编号,这个编号可以重复;还知道这个长方形的宽和长,编号、长、宽都是整数;现在要求按照一下方式排序(默认排序规则都是从小到大);
1.按照编号从小到大排序
2.对于编号相等的长方形,按照长方形的长排序;
3.如果编号和长都相同,按照长方形的宽排序;
4.如果编号、长、宽都相同,就只保留一个长方形用于排序,删除多余的长方形;最后排好序按照指定格式显示所有的长方形;

 
输入
第一行有一个整数 0<n<10000,表示接下来有n组测试数据; 每一组第一行有一个整数 0<m<1000,表示有m个长方形; 接下来的m行,每一行有三个数 ,第一个数表示长方形的编号,
第二个和第三个数值大的表示长,数值小的表示宽,相等 说明这是一个正方形(数据约定长宽与编号都小于10000);
输出
顺序输出每组数据的所有符合条件的长方形的 编号 长 宽
样例输入
  1. 1
  2. 8
  3. 1 1 1
  4. 1 1 1
  5. 1 1 2
  6. 1 2 1
  7. 1 2 2
  8. 2 1 1
  9. 2 1 2
  10. 2 2 1
样例输出
  1. 1 1 1
  2. 1 2 1
  3. 1 2 2
  4. 2 1 1
  5. 2 2 1
  1. my answer:
  1. #include<iostream>
  2. #include<algorithm>
  3. #include<cmath>
  4. using namespace std;
  5. const int MAX = ;
  6. typedef struct cil{
  7. int s;
  8. int l;
  9. int w;
  10. bool flag;
  11. }cil;
  12. cil a[MAX];
  13. int compare(cil a, cil b)
  14. {
  15. if(a.s != b.s ) return a.s < b.s;
  16. if(a.l != b.l ) return a.l < b.l;
  17. if(a.w != b.w ) return a.w < b.w;
  18. }
  19. int main()
  20. {
  21. int n;
  22. cin>>n;
  23. while(n--)
  24. {
  25. int m;
  26. cin>>m;
  27. for(int i = ; i < m; i ++){
  28. cin>>a[i].s>>a[i].l>>a[i].w;
  29. if(a[i].l < a[i].w ) swap(a[i].l,a[i].w);
  30. a[i].flag = ;
  31. }
  32. sort(a,a+m,compare);
  33. for(int i = ; i < m; i ++)
  34. {
  35. if(i != && a[i].s == a[i-].s&&a[i].l == a[i-].l &&a[i].w == a[i-].w) a[i].flag=;
  36. }
  37. for(int i = ; i < m; i++)
  38. {
  39. if (a[i].flag)
  40. cout<<a[i].s<<" "<<a[i].l<<" "<<a[i].w<<endl;
  41. }
  42. }
  43. return ;
  44. }
  1.  
  1. 参考高手代码:
  1. #include<iostream>
  2. #include<set>
  3. #include<iterator>
  4. using namespace std;
  5. struct Rect
  6. {
  7. int num,length,width;
  8.  
  9. };
  10. bool operator<(const Rect& r1,const Rect& r2)
  11. {
  12. return r1.num<r2.num || r1.num==r2.num && r1.length<r2.length ||r1.num==r2.num&&r1.length==r2.length &&r1.width<r2.width;
  13. }
  14. istream& operator>>(istream& in,Rect& r)
  15. {
  16. in>>r.num;
  17. int a,b;
  18. cin>>a>>b;
  19. r.length=max(a,b);
  20. r.width=min(a,b);
  21. return in;
  22. }
  23. ostream& operator<<(ostream& out,const Rect& r)
  24. {
  25. return out<<r.num<<" "<<r.length<<" "<<r.width;
  26. }
  27. int main()
  28. {
  29. int num;
  30. cin>>num;
  31. while(num--)
  32. {
  33. set<Rect> rs;
  34. Rect r;
  35. int n;
  36. cin>>n;
  37. while(n--)
  38. {
  39. cin>>r;
  40. rs.insert(r);
  41. }
  42. copy(rs.begin(),rs.end(),ostream_iterator<Rect>(cout,"\n"));
  43. }
  44. }
  1. 关于操作符的重载的学习:
  1. 1.输出操作符〈〈的重载:
  1. //为了与IO标准库一致,操作符应接受ostream&做为第一个形参,对类类型const对象的引用作为第二个形参,并返回对ostream形参的引用。
  1. ostream& operator <<(ostream& os , const Rect& r )
  2. {
  3. os << //....
  4. return os;
  5. }
  1. 示例:
  1. 对一个 Sales-iterm类进行重载输出操作符
  1. <pre name="code" class="cpp">ostream& operator <<(ostream& out , Sales_iterm& s)
  2. {
  3. out<<s.isbn<<"\t"<<s.units_sold<<"\t"<<s.revenue<<"\t"<<s.avg_price(); //“\t”水平制表,跳到下一个空格位置;
  4. return out;
  5. }
  1.  
  1. 第一个形参是对ostream的引用,在该对象上将产生输出。ostream为非const,因为写入到流会改变流的状态。该形参是一个引用,因为不能复制osteram对象。
  1. 第二个形参 一般应是对要输出的类类型的引用。该形参是一个引用以避免复制实参,它可以是const,因为(一般而言)输出一个对象不应该改变对象。使形参成为const引用,就可以使用同一个定义来输出const和非const对象。
  1. 返回类型是一个ostream引用,它的值通常是输出操作符ostream对象。
  1. 应该注意的是: 一般而言,输出操作符应输出对象的内容,进行最小限度的格式化,他们不应该输出换行符(换行符有清空输出缓冲区的作用。
  1. 没读懂<img alt="快哭了" src="http://static.blog.csdn.net/xheditor/xheditor_emot/default/fastcry.gif" />。。。。。。。。。
  1.  
  1.  
  1. 2.输入操作符>>的重载
  1. 与输出操作符类似,输入操作符的第一个形参是一个引用,指向它要读的流,并且返回的也是对同一个流的引用。它的第二个形参是对要读入的对象的非
  1. const引用,给引用必须为非const,因为输入操作符的目的是将数据读入到这个对象中。
  1. //更重要但是通常重视不够的是,输入和输出操作符有如下区别:输入操作符必须处理错误和文件结束的可能性。
  1. istream& operator >>(istream& in , Sales_item& s)
  2. {
  3. double price ;
  4. in>>s.isbn>>s.units_sold>>price ;
  5. if(in)
  6. s.revenue = s.units_sold * price;
  7. else
  8. s = Sales_item(); //input failed :reset object to default state
  9. return in;
  10. }

关于算数操作符和关系操作符的重载遇到再写吧。。。。。。

多关键字排序(里面有关于操作符(<<运算符 和 >>运算符 )的重载)的更多相关文章

  1. STL函数库的应用第二弹——快排sort函数与结构体关键字排序

    时隔20多天,本蒟蒻终于记起了他的博客园密码!!! 废话不多说,今天主题:STL快排函数sort()与结构体关键字排序 Part 1:引入和导语 首先,我们需要知道,algorithm库里有一些奇怪的 ...

  2. 排序技巧——双关键字排序(快速排序,sort)

    一个萌新的成长之路 Background 在做题过程中,我们常会遇到对双关键字排序的情况,如:当分数相等时,序号小的在前. 这时我们可以通过定义cmp函数作为sort的参数进行排序. Solution ...

  3. LintCode 846.多关键字排序

    LintCode 846.多关键字排序 描述 给定 n 个学生的学号(从 1 到 n 编号)以及他们的考试成绩,表示为(学号,考试成绩),请将这些学生按考试成绩降序排序,若考试成绩相同,则按学号升序排 ...

  4. SQL 按关键字排序

    SQL ORDER BY Keyword(按关键字排序) ORDER BY 关键字用于对结果集进行排序. SQL ORDER BY 关键字 ORDER BY 关键字用于按升序或降序对结果集进行排序. ...

  5. Python关键字排序

    一.当排序关键字多于1个时,我们使用lambda表达式来描述关键字key arr=[(1,4,3),(1,3,3),(2,1,4),(3,5,1)] arr.sort(key=lambda s:(s[ ...

  6. javascript运算符——位运算符

    × 目录 [1]二进制 [2]非 [3]与[4]或[5]异或[6]左移[7]右移[8]>>>[9]应用 前面的话 位运算符是非常底层的运算,由于其很不直观,所以并不常用.但是,其速度 ...

  7. 算数运算符& 关系运算符

    java中的算数运算符 + - * / % ++ -- + +: 加法运算符 - : 减法运算符 *: 乘法运算符 / : 除法运算符 注意: 除数不能为0,除数为0会报出异常 整数运算默认得到整数, ...

  8. java入门---运算符&算术运算符&自增自减运算符&关系运算符&位运算符

        计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量.我们可以把运算符分成以下几组: 算术运算符 关系运算符 位运算符 逻辑运算符 赋值运算符 ...

  9. (4)javascript的运算符以及运算符的优先级

                                    运算符的使用方法 在javascript的程序中要完成各种各样的运算,是离不开运算符的. 在javascript中,按运算符类型可以分为 ...

  10. 003-Python3-基础语法-运行方式、代码基础要求、运算符[算数运算符、比较运算符、赋值运算符、位运算符、逻辑运算符、成员运算符、身份运算符]、运算符优先级

    一.基础语法 参看地址:https://www.runoob.com/python3/python3-tutorial.html 1.1.运行方式 1.文件方式 编写一个hello.py文件, pri ...

随机推荐

  1. c++编程中的后缀

    .a 静态库 (archive) .C.c.cc.cp.cpp.cxx.c++ C++源代码(需要编译预处理) .h C或者C++源代码头文件 .ii C++源代码(不需编译预处理) .o 对象文件 ...

  2. html系列教程--p param progress rp rt ruby script select small source

    <p> 标签:用户段落划分或折行的标签 <param> 标签:param 元素允许您为插入 XHTML 文档的对象规定 run-time 设置,也就是说,此标签可为包含它的 & ...

  3. foreach真的比for性能高吗

    void Main() { ; List<int> list=new List<int>(); ;i<count;i++) { list.Add(i); } List&l ...

  4. 深入理解Java虚拟机:OutOfMemory实战

    在Java虚拟机规范的描述中,除了程序计数器外,虚拟机内存的其他几个运行时区域都有发生OutOfMemoryError(下文称OOM)异常的可能,本节将通过若干实例来验证异常发生的场景.并且会初步介绍 ...

  5. EC读书笔记系列之5:条款9、条款10

    条款9 绝不在构造和析构过程中调用virtual函数 记住: ★在构造和析构期间不要调用virtual函数,∵这类调用从不下降至derived class ---------------------- ...

  6. Linux学习之echo命令

    语法: # echo [Options] [String] 方括号中的项目是可选的.字符串可以定义为字符的有限序列(如字母,数字,符号,标点符号). 当echo命令不带任何选项或字符串使用时,它会在显 ...

  7. Android 树形菜单

    首先来一张萌萌哒的效果图(比较懒 - -) 然后是代码: // Node package com.example.treeview.utils; import java.util.ArrayList; ...

  8. Grunt之学习历程(转自网上资源-整理自用)

    认识Grunt Grunt中文文档 安装Node环境 CNode 配置Grunt Grunt中文文档-配置任务 什么是package.json package.json中文文档 关于Grunt资料 应 ...

  9. 简单的实现树莓派的WEB控制

    最终效果如图: 用到的知识:Python Bottle HTML Javascript JQuery Bootstrap AJAX 当然还有 linux 我去,这么多--我还是一点一点说起吧-- 先贴 ...

  10. SingleNumber python实现

    Single Number Given an array of integers, every element appears twice except for one. Find that sing ...