码迷,mamicode.com
首页 > 其他好文 > 详细

A - Superset CodeForces - 97B(人生第一个分治法,感觉,像二分啊。。)

时间:2017-05-06 19:13:15      阅读:367      评论:0      收藏:0      [点我收藏+]

标签:bool   函数   结构体   logs   color   deque   条件   结构   log   

/*

分治法,第一次做不是很懂,借鉴了神犇代码,但实操之后感觉像二分,,可能做得少了或者就是。。。。

*/

题目大意:

一个集合里有若干点,要求你添加某些点后保证这个集合里的任意两点满足以下三个条件中至少一个:

1.在一个水平线上 2.在一个竖直线上 3.两点组成的矩形之间有点.

解题思路:

神犇所讲,将点排序,在中间点处建一条竖直线,令其余点在其上投影,二分。

ps:不是很明白错误是什么,,结构体里重载<运算符可以,但是写个cmp函数就报错,不是很懂,贴上错误代码,如果神犇们知道什么错误,请评论告知,多谢;

错误代码

技术分享
#include<iostream>
#include <vector>
#include <algorithm>
#include <queue>
#include <stack>
#include <set>
#include <cstdio>
#include <iterator>
#include <sstream>
#include <cmath>
#include <deque>
using namespace std;

struct node
{
    int x;
    int y;
//    bool operator <(const node b)const
//    {
//        if(x==b.x) return y<b.y;
//        else return x<b.x;
//    }
};
int n;
node p1[10050];
set<node > p;
bool cmp(const node a,const node b)
{
    return a.x<b.x;
}
void dfs(int l,int h)
{
    if (l==h) return ;
    int mid;
    mid=(l+h)/2;
    for (int i=l; i<=h; i++)
    {
        node c;
        c.x=p1[mid].x;
        c.y=p1[i].y;
        p.insert(c);
    }
    dfs(l,mid);
    dfs(mid+1,h);
}
int main()
{
    cin>>n;
    for (int i=0; i<n; i++)
    {
        cin>>p1[i].x>>p1[i].y;
        p.insert(p1[i]);
    }
    sort(p1,p1+n,cmp);
    dfs(0,n-1);
    cout<<p.size()<<endl;
    set<node >::iterator it;
    for (it=p.begin(); it!=p.end(); it++)
    {
        cout<<(*it).x<<" "<<(*it).y<<endl;
    }
}
View Code

AC代码:

技术分享
#include<iostream>
#include <vector>
#include <algorithm>
#include <queue>
#include <stack>
#include <set>
#include <cstdio>
#include <iterator>
#include <sstream>
#include <cmath>
#include <deque>
using namespace std;

struct node
{
    int x;
    int y;
    bool operator <(const node b)const
    {
        if(x==b.x) return y<b.y;
        else return x<b.x;
    }
};
int n;
node p1[10050];
set<node > p;
bool cmp(const node a,const node b)
{
    return a.x<b.x;
}
void dfs(int l,int h)
{
    if (l==h) return ;
    int mid;
    mid=(l+h)/2;
    for (int i=l; i<=h; i++)
    {
        node c;
        c.x=p1[mid].x;
        c.y=p1[i].y;
        p.insert(c);
    }
    dfs(l,mid);
    dfs(mid+1,h);
}
int main()
{
    cin>>n;
    for (int i=0; i<n; i++)
    {
        cin>>p1[i].x>>p1[i].y;
        p.insert(p1[i]);
    }
    sort(p1,p1+n);
    dfs(0,n-1);
    cout<<p.size()<<endl;
    set<node >::iterator it;
    for (it=p.begin(); it!=p.end(); it++)
    {
        cout<<(*it).x<<" "<<(*it).y<<endl;
    }
}
View Code

 

A - Superset CodeForces - 97B(人生第一个分治法,感觉,像二分啊。。)

标签:bool   函数   结构体   logs   color   deque   条件   结构   log   

原文地址:http://www.cnblogs.com/SunQi-lvbu/p/6817464.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!