• 题目传送门:poj 2398 Toy Storage

  • 题目大意:一个长方形的箱子,里面有一些隔板,每一个隔板都可以纵切这个箱子。隔板将这个箱子分成了一些隔间。向其中扔一些玩具,每个玩具有一个坐标,求有\(t​\)个玩具的隔间数(对\(t>0​\)都要输出)。

  • 题目分析:涉及到计算几何的知识是求点在线的哪一侧。可以利用叉积来做。取点\(A\)到隔板的上端点\(B\)的向量\(\vec{AB}\)叉乘点\(A\)到隔板的下端点\(C\)的向量\(\vec{AC}\)。叉积的公式\(\vec a\times \vec b=|\vec a||\vec b|sin(\vec a,\vec b)\)里是有一个\(sin(\vec a,\vec b)\)的。可见若点\(A\)在\(BC\)的左侧,\((\vec{AB},\vec{AC})>\pi\)(右手法则的角度),故\(sin(\vec{AB},\vec{AC})<0\),\(\vec{AB}\times \vec{AC}<0\)。反之,点\(A\)在\(BC\)右侧,\(\vec{AB}\times \vec{AC}>0\)。这样就可以二分求每个玩具在哪个隔间里。

  • #include <cstdio>
    #include <cmath>
    #include <ctime>
    #include <cstring>
    #include <cstdlib>
    #include <algorithm>
    typedef long long LL;
    const int maxn = 1000; using namespace std; struct tPoint
    {
    int x, y;
    }; struct tCard
    {
    tPoint a, b;
    bool operator<(const tCard& y) const
    {
    if(a.x==y.a.x)
    return b.x<y.b.x;
    return a.x<y.a.x;
    }
    };
    tCard card[maxn+10]; int Multi(tPoint p1, tPoint p2, tPoint p0)
    {
    return (p1.x-p0.x) * (p2.y-p0.y) - (p2.x-p0.x) * (p1.y-p0.y);
    } int bSearch(tPoint p, int n)
    {
    int l=1, r=n;
    while(l<=r)
    {
    int mid = (l+r)/2;
    if(Multi(card[mid].a, card[mid].b, p)>0)
    l = mid+1;
    else
    r = mid-1;
    }
    return l;
    } int num[maxn+10];//partition[i]含的玩具数
    int parti[maxn+10];//含i个玩具的partition数 int main()
    {
    int n, m, x1, y1, x2, y2;
    while(scanf("%d", &n), n)
    {
    scanf("%d%d%d%d%d", &m, &x1, &y1, &x2, &y2);
    for(int i=1,u,l; i<=n; i++)
    {
    scanf("%d%d", &u, &l);
    card[i] = (tCard){(tPoint){u,y1},(tPoint){l,y2}};
    }
    card[n+1] = (tCard){(tPoint){x1,y1},(tPoint){x1,y2}};
    card[n+2] = (tCard){(tPoint){x2,y1},(tPoint){x2,y2}};
    sort(card+1, card+1+n+2); memset(num, 0, sizeof(num));
    for(int i=1; i<=m; i++)
    {
    tPoint p;
    scanf("%d%d", &p.x, &p.y);
    int part = bSearch(p, n+2) - 1;
    num[part]++;
    } memset(parti, 0, sizeof(parti));
    for(int i=1; i<=n+1; i++)
    parti[num[i]]++; printf("Box\n");
    for(int i=1; i<=maxn; i++)
    {
    if(parti[i])
    printf("%d: %d\n", i, parti[i]);
    }
    }
    return 0;
    }

poj 2398 Toy Storage(计算几何)的更多相关文章

  1. poj 2398 Toy Storage(计算几何 点线关系)

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4588   Accepted: 2718 Descr ...

  2. POJ 2398 Toy Storage(计算几何)

    题意:给定一个如上的长方形箱子,中间有n条线段,将其分为n+1个区域,给定m个玩具的坐标,统计每个区域中的玩具个数. 题解:通过斜率判断一个点是否在两条线段之间. /** 通过斜率比较点是否在两线段之 ...

  3. POJ 2318 TOYS && POJ 2398 Toy Storage(几何)

    2318 TOYS 2398 Toy Storage 题意 : 给你n块板的坐标,m个玩具的具体坐标,2318中板是有序的,而2398无序需要自己排序,2318要求输出的是每个区间内的玩具数,而231 ...

  4. POJ 2398 Toy Storage(计算几何,叉积判断点和线段的关系)

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3146   Accepted: 1798 Descr ...

  5. 2018.07.04 POJ 2398 Toy Storage(二分+简单计算几何)

    Toy Storage Time Limit: 1000MS Memory Limit: 65536K Description Mom and dad have a problem: their ch ...

  6. POJ 2398 - Toy Storage 点与直线位置关系

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5439   Accepted: 3234 Descr ...

  7. 简单几何(点与线段的位置) POJ 2318 TOYS && POJ 2398 Toy Storage

    题目传送门 题意:POJ 2318 有一个长方形,用线段划分若干区域,给若干个点,问每个区域点的分布情况 分析:点和线段的位置判断可以用叉积判断.给的线段是排好序的,但是点是无序的,所以可以用二分优化 ...

  8. 向量的叉积 POJ 2318 TOYS & POJ 2398 Toy Storage

    POJ 2318: 题目大意:给定一个盒子的左上角和右下角坐标,然后给n条线,可以将盒子分成n+1个部分,再给m个点,问每个区域内有多少各点 这个题用到关键的一步就是向量的叉积,假设一个点m在 由ab ...

  9. POJ 2398 Toy Storage (叉积判断点和线段的关系)

    题目链接 Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4104   Accepted: 2433 ...

随机推荐

  1. 隐藏input输入框的增减按钮

    当input 使用了type='number'后,会出现这个增减数值的按钮,如上所示, 解决办法: 1.type='text' ,改为输入字符串,缺点是要做类型转换,而且移动端不会调出纯数字键盘 2. ...

  2. Ubuntu 16.04上源码编译Poco并编写cmake文件 | guide to compile and install poco cpp library on ubuntu 16.04

    本文首发于个人博客https://kezunlin.me/post/281dd8cd/,欢迎阅读! guide to compile and install poco cpp library on u ...

  3. 万恶之源-python基本数据类型

    万恶之源-基本数据类型(dict) 本节主要内容: 字典的简单介绍 字典增删改查和其他操作 3. 字典的嵌套 ⼀一. 字典的简单介绍 字典(dict)是python中唯⼀一的⼀一个映射类型.他是以{ ...

  4. vue学习笔记(九)vue-cli中的组件通信

    前言 在上一篇博客vue学习笔记(八)组件校验&通信中,我们学会了vue中组件的校验和父组件向子组件传递信息以及子组件通知父组件(父子组件通信),上一篇博客也提到那是对组件内容的刚刚开始,而本 ...

  5. JavaScript算法实现之汉诺塔(Hanoi)

    目前前端新手,看到的不喜勿喷,还望大神指教. 随着Node.js,Angular.js,JQuery的流行,点燃了我学习JavaScript的热情!以后打算每天早上跟晚上抽2小时左右时间将经典的算法都 ...

  6. [从今天开始修炼数据结构]串、KMP模式匹配算法

    [从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...

  7. 08-kubernetes 存储卷

    目录 存储卷 emptyDir 测试及使用 Pod测试挂在共享NFS 写测试清单 测试 pv, pvc 创建几个PV 创建测试的Pod 和 PVC 存储卷 分为四种: 有状态,需要存储 有状态,无需存 ...

  8. Ansible Playbooks 介绍 和 使用 一

    目录 Ansible Playbooks Playbooks 组成部分: YAML 介绍 YAML 语法 Ansible 基础元素 变量 facts registre 通过命令传递变量 通过roles ...

  9. HTML 创建按钮实现跳转链接

    1.使用 form<form method="get" action="/page2"> <button type="submit& ...

  10. 2019-2020-6 20199317《Linux内核原理与分析》第六周作业

    第5章  系统调用的三层机制(下) 1  给MenuOS增加命令         首先进入LinuxKernel目录下,用rm -rf menu强制删除当前的menu目录,然后用git clone重新 ...