• <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取最近小數(shù),負數(shù)會出問題
              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
            久久天天躁狠狠躁夜夜网站| 久久无码一区二区三区少妇| 99久久99这里只有免费费精品| 久久亚洲AV无码精品色午夜| 日韩久久久久久中文人妻| 久久久久亚洲av无码专区喷水| 99久久精品国产一区二区蜜芽| 久久SE精品一区二区| 久久综合九色综合精品| 欧美黑人激情性久久| 99久久免费国产精品| 久久青青草原精品国产| 性高湖久久久久久久久AAAAA| 国产91色综合久久免费| 性高湖久久久久久久久AAAAA| 99久久精品午夜一区二区| 国产精品亚洲综合久久| 亚洲成色999久久网站| 久久婷婷五月综合国产尤物app| 久久强奷乱码老熟女网站| 精品久久久久香蕉网| 一本一本久久A久久综合精品| 性欧美大战久久久久久久| 国产精品久久久久久久久久免费| 亚洲精品无码久久久久去q| 免费一级做a爰片久久毛片潮| 91久久九九无码成人网站| 99麻豆久久久国产精品免费| 久久久久免费看成人影片| 久久亚洲AV成人出白浆无码国产 | 久久精品人人做人人爽97| 久久强奷乱码老熟女网站 | 久久99中文字幕久久| 久久精品九九亚洲精品| 欧洲精品久久久av无码电影| 久久精品国产亚洲AV久| 欧美久久久久久| 亚洲人成网亚洲欧洲无码久久| 久久人人爽人人爽人人爽| 久久99热这里只有精品66| 久久精品aⅴ无码中文字字幕不卡|