• <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>
            隨筆-21  評論-10  文章-21  trackbacks-0
              1 /*
              2  11:01 -11:21
              3  12:19 -12:54
              4  16:10 -17:03
              5  6:43 - 8:26
              6  直接x+0.5取最近小數,負數會出問題
              7  在用C風格不是很煩的前提下,盡量少用stl,更快*/
              8 #include<cmath>
              9 #include<cstdio>
             10 #include<algorithm>
             11 using namespace std;
             12 
             13 struct Star {
             14     int x, y, b;
             15     bool operator<(const Star & s)const {
             16         return x < s.x || x == s.x && y < s.y;
             17     }
             18 };
             19 Star Map[1024], Cons[1024], best[1024];
             20 int brightness, Msize, Csize, bsize;
             21 char name[128];
             22 
             23 int round(double x){
             24     return x < 0 ? x - 0.5 : x + 0.5;
             25 }
             26 
             27 int calc(Star Map [], Star Cons[], int Msize, int Csize) {
             28     if (Csize == 1) {
             29         for (int i = 0; i < Msize; i++)
             30             if (Map[i].b > brightness) {
             31                 brightness = Map[i].b;
             32                 bsize = 1;
             33                 best[0= Map[i];
             34             }
             35         return Msize;
             36     }
             37     int cnt = 0;
             38     for (int i = 0; i < Msize; i++)
             39         for (int j = 0; j < Msize; j++)
             40             if (i != j) {
             41                 Star tem[1024];
             42                 int tsize = 0;
             43                 double a = Map[j].x - Map[i].x;
             44                 double b = Map[j].y - Map[i].y;
             45                 double c = Cons[1].x - Cons[0].x;
             46                 double d = Cons[1].y - Cons[0].y;
             47                 double sinx, cosx;
             48                 sinx = (c * b - d * a) / (c*+ d*d);
             49                 cosx = (a * c + b * d) / (c*+ d*d);
             50                 tem[tsize++= Map[i];
             51                 tem[tsize++= Map[j];
             52                 int k;
             53                 for(k = 2; k < Csize; k++){
             54                     double x = cosx*(Cons[k].x - Cons[0].x) - sinx * (Cons[k].y - Cons[0].y) + Map[i].x;
             55                     double y = sinx*(Cons[k].x - Cons[0].x) + cosx * (Cons[k].y - Cons[0].y) + Map[i].y;
             56                     int ix = round(x);
             57                     int iy = round(y);
             58                     if(fabs(x - ix) > 1e-5 || fabs(y - iy) > 1e-5)break;
             59                     int t;
             60                     for(t = 0; t < Msize; t++)
             61                         if(Map[t].x == ix && Map[t].y == iy){
             62                             tem[tsize++= Map[t];
             63                             break;
             64                         }
             65                     if(t == Msize)break;
             66                 }
             67                 if(k == Csize){
             68                     cnt++;
             69                     int sum = 0;
             70                     for(int i = 0; i < tsize; i++)
             71                         sum += tem[i].b;
             72                     if(sum > brightness){
             73                         brightness = sum;
             74                         for(int i = 0; i < tsize; i++)
             75                             best[i] = tem[i];
             76                         bsize = tsize;
             77                     }
             78                 }
             79             }
             80         return cnt;
             81 }
             82 
             83 void solve() {
             84     brightness = 0;
             85     int ans = calc(Map, Cons, Msize, Csize) / calc(Cons, Cons, Csize, Csize);
             86     printf("\n%s occurs %d time(s) in the map.\n", name, ans);
             87     if (ans) {
             88         sort(best, best + bsize);
             89         printf("Brightest occurrence:");
             90         for (int i = 0; i < bsize; i++)
             91             printf(" (%d,%d)", best[i].x, best[i].y);
             92         printf("\n");
             93     }
             94 }
             95 
             96 int main() {
             97     //freopen("in", "r", stdin);
             98     int n, cas = 1;
             99     while (scanf("%d"&Msize) && Msize) {
            100         for (int i = 0; i < Msize; i++)
            101             scanf("%d %d %d"&Map[i].x, &Map[i].y, &Map[i].b);
            102         printf("Map #%d\n", cas++);
            103         for (scanf("%d"&n); n > 0; n--) {
            104             scanf("%d %s"&Csize, name);
            105             for (int i = 0; i < Csize; i++) {
            106                 scanf("%d %d"&Cons[i].x, &Cons[i].y);
            107                 Cons[i].b = 0;
            108             }
            109             solve();
            110         }
            111         printf("-----\n");
            112     }
            113 }

            posted on 2009-10-20 20:58 wangzhihao 閱讀(178) 評論(0)  編輯 收藏 引用 所屬分類: geometry
            久久婷婷五月综合国产尤物app| 久久综合亚洲色HEZYO国产| 一本久久综合亚洲鲁鲁五月天| 中文字幕人妻色偷偷久久| 久久成人精品视频| 久久久久青草线蕉综合超碰| 精品国产乱码久久久久软件| 久久精品成人国产午夜| 亚洲国产香蕉人人爽成AV片久久| 亚洲中文久久精品无码ww16| 国产精品美女久久久网AV| 精品久久久久久久| 久久久久国产精品麻豆AR影院 | 亚洲精品乱码久久久久久蜜桃| 久久精品青青草原伊人| 精产国品久久一二三产区区别| 久久久久久精品成人免费图片| 久久精品嫩草影院| 久久香蕉超碰97国产精品| 一本一道久久a久久精品综合 | 久久精品亚洲精品国产色婷| 亚洲精品乱码久久久久久蜜桃图片 | 国产精品久久久久久久久久影院| 韩国三级中文字幕hd久久精品 | 99久久国语露脸精品国产| 72种姿势欧美久久久久大黄蕉| 久久人人爽人人爽人人片AV麻豆| 精品综合久久久久久97超人| www久久久天天com| 狠狠久久综合伊人不卡| 久久99中文字幕久久| 色偷偷88888欧美精品久久久| 精品国产乱码久久久久软件| 亚洲国产天堂久久综合| 一级做a爰片久久毛片看看| 亚洲欧美一级久久精品| 欧美麻豆久久久久久中文| 久久精品国产亚洲AV久| 伊人热热久久原色播放www| 伊人色综合久久天天网| 狠狠综合久久综合88亚洲|