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

強烈推薦此題!這個題目我做了很久,始終不得其解。后來我向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 閱讀(578) 評論(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>
            欧美一区2区三区4区公司二百| 亚洲精品日韩在线观看| 欧美制服第一页| 欧美亚洲视频| 久久蜜桃精品| 欧美激情中文字幕在线| 欧美激情国产高清| 欧美日韩一区二区在线观看视频| 国产精品s色| 国产一区91| 亚洲精品美女在线观看| 亚洲无线观看| 久久精品综合| 91久久久亚洲精品| 亚洲精选中文字幕| 欧美在线|欧美| 欧美激情1区| 国产麻豆视频精品| 日韩午夜在线视频| 亚洲精品一区二区三区在线观看| 国产精品网站一区| 亚洲国产免费看| 亚洲天堂免费观看| 久久九九免费视频| 亚洲电影免费| 亚洲性视频h| 美女视频一区免费观看| 国产三级欧美三级| 狠狠色丁香久久综合频道| 亚洲激情六月丁香| 午夜视频一区二区| 亚洲国产精品久久精品怡红院| 在线视频欧美一区| 欧美成人视屏| 国产综合一区二区| 亚洲视频在线免费观看| 农夫在线精品视频免费观看| 一区二区三区免费看| 久久久另类综合| 国产精品久久一卡二卡| 亚洲高清久久网| 欧美一区二区三区视频在线观看| 男女激情久久| 欧美一区在线视频| 国产伦精品一区二区三区照片91| 久久综合网色—综合色88| 亚洲电影一级黄| 日韩网站在线| 久久久久久欧美| 国产精品日韩在线一区| 91久久嫩草影院一区二区| 久久综合影音| 亚洲免费影院| 国产色产综合产在线视频| 国产精品99久久久久久久vr| 欧美激情一区二区三区全黄| 久久久亚洲欧洲日产国码αv| 国产精品羞羞答答| 午夜精品成人在线视频| 一区二区三区国产在线观看| 牛牛影视久久网| 亚洲乱码国产乱码精品精可以看| 欧美成人免费网| 久久久久国产免费免费| 伊人夜夜躁av伊人久久| 久久综合久久综合久久| 久久一区二区精品| 136国产福利精品导航网址| 欧美h视频在线| 亚洲成在人线av| 亚洲国产一区二区三区青草影视| 久久久久九九九九| 亚洲日韩视频| 亚洲清纯自拍| 国产精品区一区二区三区| 午夜精品亚洲一区二区三区嫩草| 午夜激情综合网| 国外成人性视频| 中日韩高清电影网| 亚洲作爱视频| 欧美午夜性色大片在线观看| 亚洲欧美网站| 亚洲欧美在线免费| 好吊妞这里只有精品| 狼狼综合久久久久综合网| 老司机午夜精品视频在线观看| 亚洲日产国产精品| 99精品视频免费观看视频| 国产日韩精品久久久| 老牛嫩草一区二区三区日本 | 国产日韩欧美综合在线| 欧美一区二区三区免费视频| 香港久久久电影| 亚洲茄子视频| 一区二区免费在线视频| 在线观看三级视频欧美| 亚洲国产精品一区二区久| 国产免费成人| 欧美大秀在线观看| 国产精品久久久久9999吃药| 久久久青草青青国产亚洲免观| 两个人的视频www国产精品| 一本久道久久久| 久久aⅴ国产欧美74aaa| 99国产精品久久久久久久成人热| 亚洲四色影视在线观看| 在线成人激情黄色| 日韩视频免费观看高清完整版| 国产日韩在线一区二区三区| 亚洲大胆av| 极品av少妇一区二区| 91久久久在线| 国产在线观看一区| 中文欧美字幕免费| 亚洲国产欧美不卡在线观看| 亚洲自拍三区| 9人人澡人人爽人人精品| 亚洲欧美日韩精品在线| av成人天堂| 老司机免费视频久久| 久久一二三四| 国产精品视频第一区| 日韩一级免费观看| 亚洲经典自拍| 欧美不卡高清| 美日韩精品视频| 尹人成人综合网| 欧美在线关看| 久久精品夜色噜噜亚洲a∨| 国产精品久久| 亚洲社区在线观看| 亚洲综合国产| 欧美色图麻豆| 一区二区三欧美| 在线天堂一区av电影| 欧美日韩在线免费视频| 亚洲精品一区在线观看香蕉| 亚洲久久在线| 欧美极品影院| 一本色道久久99精品综合| 激情综合视频| 欧美激情乱人伦| 欧美一区网站| 国产精品永久免费视频| 午夜精品久久久久久久99黑人| 亚洲看片网站| 欧美日韩三级电影在线| 亚洲国产日韩欧美一区二区三区| 亚洲成人在线观看视频| 久久精品国产免费| 麻豆9191精品国产| 黑人中文字幕一区二区三区| 久久成人精品无人区| 久久国产精品久久国产精品| 国产精品乱码| 欧美在线国产| 欧美不卡在线视频| 亚洲第一精品夜夜躁人人躁| 久久蜜桃av一区精品变态类天堂| 亚洲国产日韩欧美在线图片| 亚洲精品女人| 国产日韩欧美高清| 久久阴道视频| 亚洲一级电影| 另类av导航| 亚洲视频欧美视频| 国产亚洲欧美激情| 欧美另类视频在线| 亚洲砖区区免费| 亚洲国产欧洲综合997久久| 亚洲一区二区三区免费视频| 国产欧美日韩综合一区在线观看 | 亚洲私人影院在线观看| 久久av一区二区三区| 亚洲欧洲日本mm| 欧美三级日韩三级国产三级| 欧美一区不卡| 日韩一二三区视频| 久久婷婷av| 亚洲午夜久久久久久久久电影网| 国产一区二区三区四区三区四 | 欧美粗暴jizz性欧美20| 一本色道久久| 亚洲国产欧美日韩| 国产精品毛片在线| 欧美另类一区二区三区| 欧美一二三区精品| 一本色道久久精品| 免费日韩av电影| 一本色道88久久加勒比精品| 欧美高清视频一区二区| 亚洲视频一区二区在线观看| 久久综合五月| 亚洲新中文字幕| 欧美激情精品久久久久久大尺度| 欧美在线播放| 亚洲天堂av图片| 亚洲精品美女久久久久| 国产伊人精品| 国产一区二区三区在线观看免费|