zoukankan      html  css  js  c++  java
  • 一种排序(nyoj8)(简单排序)

    一种排序

    时间限制:3000 ms  |  内存限制:65535 KB
    难度:3
    描写叙述
    如今有非常多长方形。每个长方形都有一个编号,这个编号能够反复。还知道这个长方形的宽和长,编号、长、宽都是整数;如今要求依照一下方式排序(默认排序规则都是从小到大);

    1.依照编号从小到大排序

    2.对于编号相等的长方形,依照长方形的长排序;

    3.假设编号和长都同样,依照长方形的宽排序;

    4.假设编号、长、宽都同样,就仅仅保留一个长方形用于排序,删除多余的长方形。最后排好序依照指定格式显示全部的长方形;
    输入
    第一行有一个整数 0<n<10000,表示接下来有n组測试数据;
    每一组第一行有一个整数 0<m<1000,表示有m个长方形;
    接下来的m行。每一行有三个数 ,第一个数表示长方形的编号,

    第二个和第三个数值大的表示长,数值小的表示宽,相等
    说明这是一个正方形(数据约定长宽与编号都小于10000)。
    输出
    顺序输出每组数据的全部符合条件的长方形的 编号 长 宽
    例子输入
    1
    8
    1 1 1
    1 1 1
    1 1 2
    1 2 1
    1 2 2
    2 1 1
    2 1 2
    2 2 1
    
    例子输出
    1 1 1
    1 2 1
    1 2 2
    2 1 1
    2 2 1
    来源

    经典题目

    #include<stdio.h>
    #include<algorithm>
    using namespace std;
    struct st
    {
    	int xh;
    	int c,k;
    }data[1010];
    int cmp(st a,st b)//排序关键! 
    {
    	if(a.xh!=b.xh)return a.xh<b.xh;
    	else if(a.c!=b.c)return a.c<b.c;
    	else if(a.k!=b.k)return a.k<b.k;
    }
    int main()
    {
    	int test,i,n,t;
    	scanf("%d",&test);
    	while(test--)
    	{
    		scanf("%d",&n);
    		for(i=0;i<n;i++)
    		{
    			scanf("%d%d%d",&data[i].xh,&data[i].c,&data[i].k);//注意比較长宽大小。 
    			if(data[i].c<data[i].k){
    				t=data[i].c;
    				data[i].c=data[i].k;
    				data[i].k=t;
    			}
    		}
    		sort(data,data+n,cmp);
    		for(i=0;i<n;i++)
    		{
    			if(!(data[i].xh==data[i+1].xh&&data[i].c==data[i+1].c&&data[i].k==data[i+1].k))
    			printf("%d %d %d
    ",data[i].xh,data[i].c,data[i].k);
    		}
    	}
    	return 0;
    }


  • 相关阅读:
    Struts2+Jquery实现ajax并返回json类型数据
    送给前端的你,推荐几篇前端汇总文章。(来自知乎专栏)
    使用Struts2和jQuery EasyUI实现简单CRUD系统(转载汇总)
    JavaScript、CSS、JSP 实现用户注册页面与信息校验
    Sublime-jQueryDocs
    百度CDN公共库
    Java中唯一数的生成
    MySQL主从常见的架构
    MySQL权限管理
    MySQL user表简介
  • 原文地址:https://www.cnblogs.com/gccbuaa/p/7210485.html
Copyright © 2011-2022 走看看