poj1828

【问题的描述】是这样的:程序猿的近亲 猴子(......)最近在进行王位争夺站。

题中使用二维坐标轴上的点(x,y)来代表猴子所占有的位置,

每只猴子占有一个坐标点。并且一个坐标点上面有且只有一个猴子。

如果说一直猴子是王位的继承者的话,那么这只猴子所占有的坐标(x0,y0)必须满足这样的一个条件:

一定不存在这样的一个坐标点(xi,yi)使得(xi >= x0)  and (yi >= yo).

下面需要你用程序来实现在众多组(case)二维坐标数值(x,y)中选取出

该组(case)的有可能为猴王的猴子数目的总数目。结束输入用0来表示。

输入样例:

3
2 1
1 2
3 3
3
0 1
1 0
0 0
4
0 0
1 0
0 1
1 1
0

输出样例:

1
2
1

【算法描述:】

最近才知道,对于测试case数目不一定的情况,可以用结束标志(此题为0)来做为判断循环条件,

针对一组case数据输入,跑一次算法,然后得出一个输出结果,然后将其提交给poj。

如此下来如果结果是正确的话,poj服务器端也是会AC的(好吧,这是LZ最近才知道的....)。

伪代码:

typedef struct
{
int x;
int y;
}monkey; int cmp_x(a, b)
{
monkey *m1,*m2; m1<- (monkey*)a;
m2 <- (monkey*)b if m1->x != m2->x
return m2->x - m1->x;
else
return m2->y -m1->y; }//used in inverse qsort large -> small monkey Monkey[50000]; while(~scanf( n ) && n !=0)
{
for(i 0 -> n-1)
{
scanf(Monkey[i],x, Monkey[i].y);
} qsort(Monkey, n, sizeof(monkey), cmp);
//after this sort the x (large -> small)
//and if the value of the x equal , then the value of y (large -> small) num =1;//this is use to count how many kings in the input test case maxY = monkey[0].y; for(i 1->n-1)
{
if(maxY > monkey[i].y)
{
num++;
maxY = monkey[i].y;
}
} printf (num); }

【实现代码:为以后优化代码作参照比对】

#include<stdio.h>
#include<algorithm> typedef struct
{
int x;
int y;
}monkey; monkey Monkey[];
//this is for test int cmp_x(const void *a, const void *b)
{
monkey *m1,*m2;
m1 = (monkey*)a;
m2 = (monkey*)b; if(m1->x!=m2->x)
return m2->x - m1->x;
else
return m2->y - m1->y;
} int main()
{
int n;
int i;
int num, maxY; while(~scanf("%d", &n) && n!=)
{ for(i = ; i <n; i++)
{
scanf("%d %d", &Monkey[i].x, &Monkey[i].y );
} qsort(Monkey, n, sizeof(monkey), cmp_x); num = ;
maxY = Monkey[].y; for(i = ; i < n; i++)
{
if(Monkey[i].y > maxY)
{
maxY = Monkey[i].y;
num++;
}
} printf("%d\n", num);
} }

可以看一下注释哪一行:

this is for test,因为目前做的题比较少,阅读的代码量也不是很多。

【学习总结:】每当看到别人的代码大批大批静态分配空间的时候,总是很不理解。

但是这次,LZ使用了malloc进行动态分配内存的方式,每次根据输入的n数值开辟对应的n个monkey空间。

结果优化的策略全部泡汤,时间,空间,代码量全部上升。

就目前的水平,一时半会很难找到适合的代替qsort的方法

本想用并查集来解决该问题的,目前暂时的想法是这样的:

makeSet,findSet的基本实现方法是不用做太多调整的。

而对于unionSet这一个方法就不能简单地从判断矢量高度或是集合中元素的个数来对传入的两个数据进行二者所在集合的合并。

这个还没有想好,或是从问题的条件设定根本行不通,就先放在这里吧。呵呵~

poj1828的更多相关文章

随机推荐

  1. java:找出占用CPU资源最多的那个线程(HOW TO)

    在这里对linux下.sun(oracle) JDK的线程资源占用问题的查找步骤做一个小结:linux环境下,当发现java进程占用CPU资源很高,且又要想更进一步查出哪一个java线程占用了CPU资 ...

  2. ASP.NET MVC 后台接收集合参数和 jquery ajax 传值

    MVC 接收参数数组(集合)   示例样本:   public class Person {      public string FirstName { get; set; }      publi ...

  3. 常见的Robotium测试的问题总结:

    常见的Robotium测试的问题总结:(从别处拿来的先mark一下) 1.Robotium的 测试类ActivityInstrumentationTestCase2继承了TestCase类,即robo ...

  4. nginx -- handler模块(100%)

    handler模块简介 相信大家在看了前一章的模块概述以后,都对nginx的模块有了一个基本的认识.基本上作为第三方开发者最可能开发的就是三种类型的模块,即handler,filter和load-ba ...

  5. 【转】vc中使用SendMessage正确发送自定义消息的方法--不错

    原文网址:http://zhoumf1214.blog.163.com/blog/static/5241940200910265532959/ 最近在用VC2008做开发,后来由于要用到消息的发送,而 ...

  6. Selenium 设置管理cookie,超时时间

    可以通过option设置管理cookie,超时时间 一.cookie机制和session机制的区别 具体来说cookie机制采用的是在客户端保持状态的方案,储存在内存.而session机制采用的是在服 ...

  7. Sysrq 诊断系统故障 与 gdb 调试core dump

    1. 典型应用场景如:    1)系统进入了挂死状态(如调度出现异常.或系统负荷过重),但仍能响应中断,此时可以通过Sysrq魔术键(c)手工触发panic,结合kdump,就能收集到vmcore信息 ...

  8. Mathlab编程-微积分在Matlab中的解法

    这一章节将介绍一系列典型的微积分问题(求极限.级数.定积分.导数.重积分等)在Matlab中的求解. 首先关于极限: (1)    数列极限: 给出下面三段例程. 求解数列极限的limit函数参数说明 ...

  9. Codeforces 350B Resort

    题目链接:http://codeforces.com/problemset/problem/350/B 一开始想复杂了,建了张图,结果效率太低T了.其实用数组存可以了,结果发现的时候快没时间了,修改好 ...

  10. kafka offset-check工具失效的问题

    转载请注明原创地址http://www.cnblogs.com/dongxiao-yang/p/5414077.html 由于平时业务预警等需求,针对现在公司的kafka系统部署了几套监控系统,包括调 ...