青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

強烈推薦此題!這個題目我做了很久,始終不得其解。后來我向dm求教,他發來代碼。我對照數據才過的。
先考察一下這個問題的性質。
性質1:任何一個圓都覆蓋了一個閉區域。
性質2:對于任意一個點,覆蓋它的最上面的那個圓,一定是可見的。
性質3:如果一個圓不可見(它被完全覆蓋),那么它的邊界是被完全覆蓋的。
性質4:n 個圓最多有2(n-1)2個交點,這些交點把 n 個圓分成最多2(n-1)2條小圓弧。
性質5:對于每個小圓弧,要么它全被覆蓋,要么它全不被覆蓋。
根據性質1和性質2,問題轉化為恰當地找出一些點,對于每個點,把覆蓋它的最上面的圓標記為可見。
根據性質3,這些點一定在所有圓的邊界集合內。
根據性質5,所有小圓弧構成邊界集合。每個小圓弧上只要任意取一個點就能代表整個小圓弧(邊界)。不妨取中點。
至此得到算法:取所有小圓弧的中點,對每個點找到覆蓋它的最上面的圓。
根據性質4,最多取2(n-1)2個點。對每個點找到覆蓋它的最上面的圓,需要O(n)次運算。總復雜度是O(n3)。
其實此算法還有冗余,有些內部小圓弧可以不用考慮,但是我沒想出怎么優化。有誰知道更好的算法,請聯系我。blog留言或者qq交談或者發郵件都可以。


/*************************************************************************
Author: WHU_GCC
Created Time: 2007-8-24 12:33:03
File Name: pku1418.cpp
Description: 
***********************************************************************
*/

#include 
<iostream>
#include 
<algorithm>
#include 
<vector>
#include 
<complex>
#include 
<cmath>
using namespace std;
#define out(x) (cout << #x << ": " << x << endl)
const int maxint = 0x7FFFFFFF;
typedef 
long long int64;
const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;
template 
<class T> void show(T a, int n) {for (int i = 0; i < n; ++i) cout << a[i] << ' '; cout << endl; }
template 
<class T> void show(T a, int r, int l) {for (int i = 0; i < r; ++i) show(a[i], l); cout << endl; }

typedef complex 
<double> xy;

const double PI = acos(-1.0);

double normalize(double r)
{
    
while (r < 0.0) r += 2 * PI;
    
while (r >= 2 * PI) r -= 2 * PI;
    
return r;
}


int highest_cover(xy p, vector <xy> &points, vector <double> &rs)
{
    
for (int i = rs.size() - 1; i >= 0; i--)
        
if (abs(points[i] - p) < rs[i])
            
return i;
    
return -1;
}


int main()
{
    
while (1)
    
{
        
int n;
        cin 
>> n;
        
if (!n) break;
        vector 
<xy> points;
        vector 
<double> rs;
        
for (int i = 0; i < n; i++)
        
{
            
double x, y, r;
            cin 
>> x >> y >> r;
            points.push_back(xy(x, y));
            rs.push_back(r);
        }

        vector 
<bool> visible(n, false);
        
for (int i = 0; i < n; i++)
        
{
            vector 
<double> rads;
            rads.push_back(
0.0);
            rads.push_back(
2.0 * PI);
            
for (int j = 0; j < n; j++)
            
{
                
double a = rs[i];
                
double b = abs(points[j] - points[i]);
                
double c = rs[j];
                
if (a + b < c || a + c < b || b + c < a) continue;
                
double d = arg(points[j] - points[i]);
                
double e = acos((a * a + b * b - c * c) / (2 * a * b));
                rads.push_back(normalize(d 
+ e));
                rads.push_back(normalize(d 
- e));
            }

            sort(rads.begin(), rads.end());
            
for (int j = 0; j < rads.size() - 1; j++)
            
{
                
double rad = (rads[j + 1+ rads[j]) / 2.0;
                
double diff = 4E-13;
                
for (int k = -1; k <= 1; k += 2)
                
{
                    
int t = highest_cover(xy(points[i].real() + (rs[i] + diff * k) * cos(rad),
                        points[i].imag() 
+ (rs[i] + diff * k) * sin(rad)),
                        points, rs);
                    
if (t != -1) visible[t] = true;
                }

            }

        }

        
int ans = 0;
        
for (int i = 0; i < n; i++)
            
if (visible[i])
                ans
++;
        cout 
<< ans << endl;
    }

    
return 0;
}
posted on 2007-08-24 22:43 Felicia 閱讀(579) 評論(2)  編輯 收藏 引用 所屬分類: 計算幾何
Comments
  • # re: [計算幾何]pku1418
    巫山霏云
    Posted @ 2007-08-24 23:03
    贊...加油  回復  更多評論   
  • # re: [計算幾何]pku1418
    Felicia
    Posted @ 2007-10-16 22:09
    注意,求覆蓋圓弧中點的最上圓時,有一個小技巧,就是把這個中點向內、向外分別偏移一個微小的距離  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            红桃视频国产精品| 国产区精品视频| 亚洲精品极品| 亚洲国产精品专区久久 | 一本色道久久综合亚洲精品小说 | 开元免费观看欧美电视剧网站| 国内综合精品午夜久久资源| 久久人人爽国产| 美女脱光内衣内裤视频久久影院| 亚洲国产精品一区二区第四页av| 亚洲国产高清自拍| 欧美性事在线| 久久精品视频在线| 女女同性精品视频| 亚洲在线一区二区| 亚洲欧美日韩电影| 亚洲精品精选| 国产视频亚洲| 久久亚洲综合| 农村妇女精品| 亚洲欧美国产视频| 欧美一级在线播放| 亚洲另类视频| 欧美亚洲免费在线| 亚洲国产成人久久综合| 99这里只有精品| 尤物yw午夜国产精品视频| 亚洲激情社区| 国产欧美69| 亚洲日产国产精品| 国产一在线精品一区在线观看| 亚洲第一综合天堂另类专| 国产精品试看| 91久久一区二区| 国模精品一区二区三区| 亚洲精品视频在线观看网站| 国产亚洲午夜| 一本色道久久加勒比精品| 亚洲国产精品t66y| 香蕉久久a毛片| 在线一区二区三区四区| 久久久久国产成人精品亚洲午夜| 亚洲在线黄色| 欧美激情aⅴ一区二区三区| 久久久99国产精品免费| 国产精品久久久久久久久久ktv| 亚洲二区在线| 激情av一区| 欧美在线观看日本一区| 亚洲曰本av电影| 欧美精品黄色| 亚洲黄色免费电影| 红桃视频亚洲| 久久精品91| 久久激情综合网| 国产精品高潮久久| 亚洲免费不卡| 一区二区电影免费观看| 久久五月天婷婷| 久久免费少妇高潮久久精品99| 国产精品久久久久久久久搜平片| 亚洲美女淫视频| 99这里只有精品| 欧美日韩免费观看一区二区三区| 亚洲观看高清完整版在线观看| 亚洲第一搞黄网站| 久久综合五月天婷婷伊人| 蜜桃av一区二区三区| 在线观看视频一区二区| 久久电影一区| 女生裸体视频一区二区三区| 影音先锋日韩有码| 久久午夜激情| 欧美激情四色| 亚洲国产精品尤物yw在线观看| 久久久久久午夜| 欧美成人精品| 一区二区三区三区在线| 欧美日韩高清一区| 亚洲社区在线观看| 性色av一区二区三区在线观看| 国产精品色婷婷久久58| 欧美一区国产二区| 欧美大片第1页| 99国产一区| 国产精品伦理| 久久精品亚洲| 亚洲国产日韩综合一区| 亚洲欧美高清| 在线观看国产日韩| 欧美精选在线| 亚洲伊人第一页| 久久久久久久性| 最新亚洲一区| 欧美婷婷六月丁香综合色| 亚洲欧美一级二级三级| 欧美插天视频在线播放| 99这里只有久久精品视频| 国产欧美一区二区三区久久| 老司机免费视频久久| 一本色道久久88亚洲综合88| 久久琪琪电影院| 亚洲精品国精品久久99热一| 国产精品入口日韩视频大尺度| 久久国产手机看片| 99精品国产在热久久| 久久高清福利视频| 99精品欧美一区二区蜜桃免费| 国产日韩欧美精品在线| 欧美成人精品激情在线观看| 99国内精品久久| 欧美多人爱爱视频网站| 午夜精品一区二区在线观看| 91久久精品久久国产性色也91| 国产精品捆绑调教| 欧美精品久久一区二区| 欧美在线综合视频| 夜夜狂射影院欧美极品| 亚洲第一视频网站| 久久综合一区二区三区| 亚洲综合导航| 一本在线高清不卡dvd| 在线日韩成人| 国产午夜亚洲精品理论片色戒 | 亚洲黄网站在线观看| 欧美在线播放一区| 亚洲图片自拍偷拍| 91久久午夜| 精品成人在线| 国产日韩精品在线| 国产精品久久久久久亚洲调教 | 欧美日韩色婷婷| 久热精品视频在线观看一区| 亚洲欧美另类在线观看| 99在线精品观看| 最新国产成人在线观看| 欧美韩国日本综合| 麻豆av一区二区三区| 久久免费视频这里只有精品| 欧美一级久久久| 性欧美精品高清| 亚洲欧美中文日韩v在线观看| 中日韩美女免费视频网址在线观看 | 国产精品99久久不卡二区| 亚洲激情成人网| 亚洲国产精品久久久久秋霞影院| 韩日午夜在线资源一区二区| 国产亚洲日本欧美韩国| 国产一区二区剧情av在线| 国产精品视频精品视频| 国产欧美一区二区精品仙草咪| 国产精品视频九色porn| 国产精品永久免费在线| 国产视频一区在线观看| 国产午夜精品一区理论片飘花| 国产一区二区三区日韩欧美| 国内成+人亚洲| 亚洲国产专区| 日韩亚洲一区二区| 亚洲主播在线观看| 久久国产精品一区二区三区四区| 久久久久高清| 蘑菇福利视频一区播放| 亚洲第一精品夜夜躁人人爽| 亚洲日本中文字幕区| 亚洲一区二三| 久久视频国产精品免费视频在线| 欧美阿v一级看视频| 欧美日韩国产综合新一区| 国产精品捆绑调教| 黄色亚洲大片免费在线观看| 亚洲激情偷拍| 亚洲免费影视| 巨乳诱惑日韩免费av| 亚洲国产欧美日韩另类综合| 在线综合亚洲| 久久国产精品99久久久久久老狼| 欧美大秀在线观看| 国产伦精品一区二区三区| 亚洲国产高清在线| 亚洲男人的天堂在线aⅴ视频| 久久乐国产精品| 亚洲精品在线免费观看视频| 欧美一区91| 亚洲国产精品视频一区| 制服丝袜亚洲播放| 久久精品国产999大香线蕉| 欧美成ee人免费视频| 一本色道久久99精品综合| 久久久精品动漫| 欧美三级视频| 亚洲黄色天堂| 欧美一区激情视频在线观看| 欧美成人精品福利| 亚洲一区二区综合| 欧美精品1区| 揄拍成人国产精品视频| 午夜在线电影亚洲一区| 亚洲日韩成人| 久久一区二区精品|