• <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 閱讀(181) 評論(0)  編輯 收藏 引用 所屬分類: geometry
            亚洲AV无码成人网站久久精品大| 久久久亚洲AV波多野结衣| 青青青国产精品国产精品久久久久| 91精品国产9l久久久久| 久久99精品久久久久久不卡| 一本色道久久99一综合| 国产日韩欧美久久| 久久久亚洲欧洲日产国码aⅴ | 国产精品美女久久久| 久久国产免费| 国产精品99精品久久免费| 久久精品亚洲精品国产欧美| 99久久精品影院老鸭窝| 色婷婷综合久久久久中文字幕 | 草草久久久无码国产专区| 久久香综合精品久久伊人| 国产午夜精品久久久久九九| 国产婷婷成人久久Av免费高清| 亚洲精品高清一二区久久 | 欧美激情一区二区久久久| 99久久无码一区人妻| 国产精品久久午夜夜伦鲁鲁| 亚洲综合伊人久久大杳蕉| 国产福利电影一区二区三区久久久久成人精品综合 | 国产精品久久久久无码av| 亚洲AV日韩AV永久无码久久| 欧美色综合久久久久久| 国产一区二区三精品久久久无广告| 97久久精品无码一区二区 | 人人狠狠综合久久亚洲88| 99久久人妻无码精品系列| 亚洲国产精品久久电影欧美| 亚洲日本久久久午夜精品| 亚洲午夜福利精品久久| 深夜久久AAAAA级毛片免费看| 久久久精品久久久久久| 久久久久九九精品影院| 久久91精品国产91久| 亚洲愉拍99热成人精品热久久| 国内精品伊人久久久久777| 亚洲AV无一区二区三区久久|