传送门——Vjudge


三分写法似乎有问题,可以去Udebug上看Morass的\(666\)个测试点的数据,我的乱搞有很多比正解答案小,但还是能在SPOJ和POJ过,可见数据之水。

可以对正方形的角度模拟退火,然后旋转坐标系将正方形变成平行与坐标轴的正方形,这样我们只需计算旋转坐标系之后的所有点中\(x/y\) 最大/最小的点就可以算出正方形的边长,而旋转坐标系之后的点的坐标可以通过两角相加的\(sin\)和\(cos\)公式得到。

但很奇怪的一件事情是传统的模拟退火过不了样例……

我的乱搞写法同时借鉴了模拟退火和贪心,其实就是模拟退火中“如果\(\Delta ans < 0\),则有\(e^{\frac{\Delta ans}{T}}\)的概率选择较不优的状态”这个过程去掉,每一次更优就选,不优就不选,具体为什么这样就对了我也不晓得QAQ。然后多做几次取平均值就可以得到答案。

#include<iostream>
#include<cstdio>
#include<cctype>
#include<algorithm>
#include<iomanip>
#include<cmath>
#include<ctime>
//This code is written by Itst
using namespace std;

#define ld long double
const int times = 8;
const ld pi = acos(-1) , eps = 1e-10 , delta = 0.985 , init = 5e5;
int T , N , node[101][2];

ld calc(ld mid){
    ld maxX = -1e18 , maxY = -1e18 , minX = 1e18 , minY = 1e18;
    ld Cos = cos(mid) , Sin = sin(mid);
    for(int i = 1 ; i <= N ; ++i){
        ld x = node[i][0] * Cos - node[i][1] * Sin , y = node[i][0] * Sin + node[i][1] * Cos;
        maxX = max(maxX , x); minX = min(minX , x);
        maxY = max(maxY , y); minY = min(minY , y);
    }
    return max(maxX - minX , maxY - minY);
}

int main(){
#ifndef ONLINE_JUDGE
    freopen("in","r",stdin);
    freopen("out","w",stdout);
#endif
    srand((unsigned)time(0));
    for(cin >> T ; T ; --T){
        cin >> N;
        for(int i = 1 ; i <= N ; ++i)
            cin >> node[i][0] >> node[i][1];
        ld all = 0;
        for(int i = 1 ; i <= times ; ++i){
            ld temp = init , cur = 0 , ans = calc(cur) * calc(cur);
            while(temp > eps){
                ld tmp = cur + (rand() * 2 - RAND_MAX) * temp / init / RAND_MAX * pi;
                ld ansT = calc(tmp) * calc(tmp);
                if(ans > ansT){
                    ans = ansT;
                    cur = tmp;
                }
                temp *= delta;
            }
            all += ans;
        }
        cout << fixed << setprecision(2) << all / times << endl;
    }
    return 0;
}

POJ3301 Texas Trip 计算几何、随机化贪心的更多相关文章

  1. poj3301 Texas Trip【三分算法】

    题目地址:http://poj.org/problem?id=3301 简述:T组测试数据,每组线输入n,代表有n个点,接下来输入这n个点的坐标,坐标都是整数. 要求用一个最小的正方形覆盖所有的点,输 ...

  2. 三分 --- POJ 3301 Texas Trip

    Texas Trip Problem's Link:   http://poj.org/problem?id=3301 Mean: 给定n(n <= 30)个点,求出包含这些点的面积最小的正方形 ...

  3. 2018.08.29 NOIP模拟 movie(状压dp/随机化贪心)

    [描述] 小石头喜欢看电影,选择有 N 部电影可供选择,每一部电影会在一天的不同时段播 放.他希望连续看 L 分钟的电影.因为电影院是他家开的,所以他可以在一部电影播放过程中任何时间进入或退出,当然他 ...

  4. 2018.08.09洛谷P3959 宝藏(随机化贪心)

    传送门 回想起了自己赛场上乱搜的20分. 好吧现在也就是写了一个随机化贪心就水过去了,不得不说随机化贪心大法好. 代码: #include<bits/stdc++.h> using nam ...

  5. BZOJ.2428.[HAOI2006]均分数据(随机化贪心/模拟退火)

    题目链接 模拟退火: 模拟退火!每次随机一个位置加给sum[]最小的组. 参数真特么玄学啊..气的不想调了(其实就是想刷刷最优解) 如果用DP去算好像更准.. //832kb 428ms #inclu ...

  6. 洛谷 P2503 [HAOI2006]均分数据 随机化贪心

    洛谷P2503 [HAOI2006]均分数据(随机化贪心) 现在来看这个题就是水题,但模拟赛时想了1个小时贪心,推了一堆结论,最后发现贪心做 不了, 又想了半个小时dp 发现dp好像也做不了,在随机化 ...

  7. POJ 3301:Texas Trip(计算几何+三分)

    http://poj.org/problem?id=3301 题意:在二维平面上有n个点,每个点有一个坐标,问需要的正方形最小面积是多少可以覆盖所有的点. 思路:从第二个样例可以看出,将正方形旋转45 ...

  8. UVA 11100 The Trip, 2007 (贪心)

    题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...

  9. poj 3301 Texas Trip(几何+三分)

    Description After a day trip with his friend Dick, Harry noticed a strange pattern of tiny holes in ...

随机推荐

  1. 长文本溢出显示省略号(…) text-overflow: ellipsis

    text-overflow 属性规定当文本溢出包含元素时发生的事情. 默认值: clip 继承性: no 版本: CSS3 JavaScript 语法: object .style.textOverf ...

  2. loadrunner 场景设计-添加Unix、Linux Resources计数器

    场景设计-添加Unix.Linux Resources计数器 by:授客 QQ:1033553122 A.   目的 监控要测试的Unix.Linux服务器的资源使用情况 Linux CentOS为例 ...

  3. Android解析XML文件

    XML文件和获取XML值 XML文件样例 <?xml version="1.0" encoding="utf-8"?> <citys> ...

  4. flask中的url_for的使用

    有多个路由的程序需要连接不同的网页链接,例如导航条 模板中构建正确的动态url较为困难,如果重定义路由,模板中的链接失效 url_for()函数: 使用url映射中保存的信息生成url 用法: 用视图 ...

  5. React Refs

    React Refs React 支持一种非常特殊的属性 Ref ,你可以用来绑定到 render() 输出的任何组件上. 这个特殊的属性允许你引用 render() 返回的相应的支撑实例( back ...

  6. Oracle EBS FA 获取累计折旧

    FUNCTION get_ltd_deprn(p_asset_id IN NUMBER, p_book_type_code IN VARCHAR2, p_rate_source_rule IN VAR ...

  7. python第二十天

    logging模块 re正则表达式

  8. EntityFramework Code-First 简易教程(五)-------领域类配置

    前言:在前篇中,总是把领域类(Domain Class)翻译成模型类,因为我的理解它就是一个现实对象的抽象模型,不知道对不对.以防止将来可能的歧义,这篇开始还是直接对Domain Class直译. 前 ...

  9. MySQL崩溃恢复与组提交

      Ⅰ.binlog与redo的一致性(原子) 由内部分布式事务保证 我们先来了解下,当一个commit敲下后,内部会发生什么? 步骤 操作 step1 InnoDB做prepare redo log ...

  10. java针对不同方法的分页

    一.常见的分页实现方式 ①使用List接口中的subList(int startIndex,int endIndex)方法实现分页 ②直接使用数据库SQL语句实现分页 ③使用hibernate等框架实 ...