The dog task

Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 3272   Accepted: 1313   Special Judge

Description

Hunter Bob often walks with his dog Ralph. Bob walks with a constant speed and his route is a polygonal line (possibly self-intersecting) whose vertices are specified by N pairs of integers (Xi, Yi) ? their Cartesian coordinates.
Ralph walks on his own way but always meets his master at the
specified N points. The dog starts his journey simultaneously with Bob
at the point (X1, Y1) and finishes it also simultaneously with Bob at
the point (XN, YN).

Ralph can travel at a speed that is up to two times greater than his
master's speed. While Bob travels in a straight line from one point to
another the cheerful dog seeks trees, bushes, hummocks and all other
kinds of interesting places of the local landscape which are specified
by M pairs of integers (Xj',Yj'). However, after leaving his master at
the point (Xi, Yi) (where 1 <= i < N) the dog visits at most one
interesting place before meeting his master again at the point (Xi+1,
Yi+1).

Your task is to find the dog's route, which meets the above
requirements and allows him to visit the maximal possible number of
interesting places. The answer should be presented as a polygonal line
that represents Ralph's route. The vertices of this route should be all
points (Xi, Yi) and the maximal number of interesting places (Xj',Yj').
The latter should be visited (i.e. listed in the route description) at
most once.

An example of Bob's route (solid line), a set of interesting places
(dots) and one of the best Ralph's routes (dotted line) are presented in
the following picture:

Input

The
first line of the input contains two integers N and M, separated by a
space ( 2 <= N <= 100 ,0 <= M <=100 ). The second line
contains N pairs of integers X1, Y1, ..., XN, YN, separated by spaces,
that represent Bob's route. The third line contains M pairs of integers
X1',Y1',...,XM',YM', separated by spaces, that represent interesting
places.

All points in the input file are different and their coordinates are integers not greater than 1000 by the absolute value.

Output

The
first line of the output should contain the single integer K ? the
number of vertices of the best dog's route. The second line should
contain K pairs of coordinates X1'',Y1'' , ...,Xk'',Yk'', separated by
spaces, that represent this route. If there are several such routes,
then you may write any of them.

Sample Input

4 5
1 4 5 7 5 2 -2 4
-4 -2 3 9 1 2 -1 3 8 -3

Sample Output

6
1 4 3 9 5 7 5 2 1 2 -2 4

Source

 
分析:
1、注意最重要的一个条件:狗每次最多去一个interesting place;
2、一处英文错误,狗的速度是人的两倍;
 
解题:典型的二分图最大匹配问题,用匈牙利算法。
 
 Source Code
Problem:
Memory: 416K Time: 16MS
Language: GCC Result: Accepted #include <stdio.h>
#include <math.h>
#include <string.h> #define DOG_SPEED 2 #define MAX_POINT_NUM 101 #define TRUE (int)1
#define FALSE (int)0 typedef int BOOL; typedef struct
{
int x;
int y;
}Point; typedef struct
{
int num;
Point pos[MAX_POINT_NUM];
}Points; Points g_Bob;
Points g_interests;
BOOL g_isOccupied[MAX_POINT_NUM];
int g_len[MAX_POINT_NUM][MAX_POINT_NUM];
int g_selectNum;
int g_selectIdx[MAX_POINT_NUM];
int g_BobToInterest[MAX_POINT_NUM]; void Input()
{
int i; scanf("%d %d", &g_Bob.num, &g_interests.num); for(i = ; i < g_Bob.num; i++)
{
scanf("%d %d", &g_Bob.pos[i].x, &g_Bob.pos[i].y);
} for(i = ; i < g_interests.num; i++)
{
scanf("%d %d", &g_interests.pos[i].x, &g_interests.pos[i].y);
} g_selectNum = ;
memset(g_len, -, sizeof(g_len));
memset(g_selectIdx, -, sizeof(g_selectIdx));
memset(g_BobToInterest, -, sizeof(g_BobToInterest));
} void Output()
{
int bobIdx, interestIdx; printf("%d\n", g_Bob.num+g_selectNum); for(bobIdx = ; bobIdx < g_Bob.num; bobIdx++)
{
printf("%d %d ", g_Bob.pos[bobIdx].x, g_Bob.pos[bobIdx].y);
interestIdx = g_BobToInterest[bobIdx];
if(interestIdx != -) printf("%d %d ", g_interests.pos[interestIdx].x, g_interests.pos[interestIdx].y);
}
} static double CalcLen(Point* m, Point* n)
{
double x = m->x - n->x;
double y = m->y - n->y; return sqrt(x*x+y*y);
} int IsLenSatisfied(int bobIdx, int interestIdx)
{
double bobLen, dogLen1, dogLen2; if(g_len[bobIdx][interestIdx] == -)
{
bobLen = CalcLen(&g_Bob.pos[bobIdx], &g_Bob.pos[bobIdx+]);
dogLen1 = CalcLen(&g_Bob.pos[bobIdx], &g_interests.pos[interestIdx]);
dogLen2 = CalcLen(&g_Bob.pos[bobIdx+], &g_interests.pos[interestIdx]);
g_len[bobIdx][interestIdx] = ((bobLen*DOG_SPEED) >= (dogLen1+dogLen2)) ? : ;
}
return g_len[bobIdx][interestIdx];
} BOOL DogFinding(int bobIdx)
{
int interestIdx; for(interestIdx = ; interestIdx < g_interests.num; interestIdx++)
{
if(!g_isOccupied[interestIdx] && IsLenSatisfied(bobIdx, interestIdx))
{
g_isOccupied[interestIdx] = TRUE;
if(g_selectIdx[interestIdx] == - || DogFinding(g_selectIdx[interestIdx]))
{
g_selectIdx[interestIdx] = bobIdx;
g_BobToInterest[bobIdx] = interestIdx;
return TRUE;
}
}
} return FALSE;
} void Proc()
{
int bobIdx;
for(bobIdx = ; bobIdx < g_Bob.num-; bobIdx++)
{
memset(g_isOccupied, , sizeof(g_isOccupied));
if(DogFinding(bobIdx)) g_selectNum++;
}
} int main()
{
Input();
Proc();
Output();
return ;
}

北大poj- 1034的更多相关文章

  1. 北大POJ题库使用指南

    原文地址:北大POJ题库使用指南 北大ACM题分类主流算法: 1.搜索 //回溯 2.DP(动态规划)//记忆化搜索 3.贪心 4.图论 //最短路径.最小生成树.网络流 5.数论 //组合数学(排列 ...

  2. POJ 1034 The dog task(二分图匹配)

    http://poj.org/problem?id=1034 题意: 猎人和狗一起出去,狗的速度是猎人的两倍,给出猎人的路径坐标,除了这些坐标外,地图上还有一些有趣的点,而我们的狗,就是要尽量去多的有 ...

  3. poj 1034 The dog task (二分匹配)

    The dog task Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 2559   Accepted: 1038   Sp ...

  4. 【Java】深深跪了,OJ题目Java与C运行效率对比(附带清华北大OJ内存计算的对比)

    看了园友的评论之后,我也好奇清橙OJ是怎么计算内存占用的.重新测试的情况附在原文后边. -------------------------------------- 这是切割线 ----------- ...

  5. POJ 1861 Network (Kruskal算法+输出的最小生成树里最长的边==最后加入生成树的边权 *【模板】)

    Network Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 14021   Accepted: 5484   Specia ...

  6. 各大OJ

    北大POJ 杭电HDU 浙大ZOj 蓝桥杯 PAT

  7. leetcode学习笔记--开篇

    1 LeetCode是什么? LeetCode是一个在线的编程测试平台,国内也有类似的Online Judge平台.程序开发人员可以通过在线刷题,提高对于算法和数据结构的理解能力,夯实自己的编程基础. ...

  8. OJ题目JAVA与C运行效率对比

    [JAVA]深深跪了,OJ题目JAVA与C运行效率对比(附带清华北大OJ内存计算的对比) 看了园友的评论之后,我也好奇清橙OJ是怎么计算内存占用的.重新测试的情况附在原文后边. ----------- ...

  9. C++ 指针常见用法小结

    1. 概论 2.指针基础 3. 指针进阶 4. 一维数组的定义与初始化 5. 指针和数组 6. 指针运算 7. 多维数组和指针 8. 指针形参 9. 数组形参 10. 返回指针和数组 11. 结语   ...

  10. 几个比較好的IT站和开发库官网

    几个比較好的IT站和开发库官网 1.IT技术.项目类站点 (1)首推CodeProject,一个国外的IT站点,官网地址为:http://www.codeproject.com,这个站点为程序开发人员 ...

随机推荐

  1. 自学PYTHON分享 --基础1

    1.python2和python3的区别: 宏观上:python2 与 python3 区别: python2 源码不标准,混乱,重复代码太多, python3 统一 标准,去除重复代码. 2.pyt ...

  2. QSS 记录

    1.border-style 属性分别有 none 定义无边框. hidden 与 "none" 相同.不过应用于表时除外,对于表,hidden 用于解决边框冲突. dotted ...

  3. 使用 Laragon 在 Windows 中快速搭建 Laravel 本地开发环境 (转)

    laravel学院 简介 对于那些使用 Windows 操作系统的同学来说,Homestead 和 LaraDock 虽说支持 Windows 系统,但是对初学者来说,安装配置起来还是有一定复杂度的, ...

  4. JS回调函数中的this指向(详细)

    首先先说下正常的this指向问题 什么是this:自动引用正在调用当前方法的.前的对象. this指向的三种情况 1. obj.fun()     fun中的this->obj,自动指向.前的对 ...

  5. Cookie、Session和自定义分页

    一.cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响, ...

  6. [LeetCode] 26. Remove Duplicates from Sorted Array ☆(从有序数组中删除重复项)

    [LeetCode] Remove Duplicates from Sorted Array 有序数组中去除重复项 描述 Given a sorted array nums, remove the d ...

  7. 6种纯css实现loading效果

    1. <div id="loadingWrap1"> <span></span> <span></span> <s ...

  8. windows—IOCP

    一.重叠I/O回声服务器端 服务端: #include <stdio.h> #include <stdlib.h> #include <WinSock2.h> #d ...

  9. 小程序一个大盒子里面的盒子内容居中对其显示wxss写法

    对小程序研究感兴趣的可加(交流QQ群:604788754)入群联系群主可得到小程序教学资源. 这个案例只是想展示效果,内容部分未进行for循环绑定处理: WXML: <view class=&q ...

  10. FastCGI 进程意外退出造成500错误

    在一台新服务器上,安装新网站,之前只放至了一个网站.是服务器商配置好的,非集成环境. 添加了一个新站,路径都制定好了,但是在访问时出现了500错误.提示貌似是php的问题,但是之前的网站,运行的是di ...