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;
    }


  • 相关阅读:
    2019春季第五周作业
    2019春第四周作业(基础题)计算机
    2019第三周作业
    第二周基础作业
    2019春第九周作业
    2019年春第八周作业
    第七周总结
    第六周作业
    2019春第五周作业
    2019年春季学期第四周作业
  • 原文地址:https://www.cnblogs.com/gccbuaa/p/7210485.html
Copyright © 2011-2022 走看看