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

bon

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  46 Posts :: 0 Stories :: 12 Comments :: 0 Trackbacks

常用鏈接

留言簿(2)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

poj 3349

本來不想看discuss了,不過因為這道題拖太久了,所以還是看了一下^_^,不過算法還是自己想的。
之前程序已經做好了,但一直WA,估計不是算法的錯,而是程序的錯。

這道題給了兩個啟示:
1. 點的哈希函數:我是把坐標值(六個整數值)求和模149997,哈希表長度是150000。嚴蔚敏的《數據結構》指出:模的數可以選為質數或不包
    含小于20的質因數的合數。另外這個數要盡量接近哈希表長度,這樣才能有效利用哈希表的空間,而不會使得數據集中在前面。

2. 有大量輸入時(100000×6個整數),每個整數最長有7位,這時用getchar()輸入字符再轉成整數會比scanf()輸入整數快很多!(2438ms VS 610ms)

3. 這道題的數據可以是這樣:1 2 3 1 5 6 與 1 5 6 1 2 3是同一朵雪花,但我之前的程序沒有判斷出來。具體看下面程序里的equal函數。

  1 #include <iostream>
  2 #include <set>
  3 
  4 using namespace std;
  5 
  6 const int maxn=150000;
  7 struct node{
  8     node(){idx=-1;next=NULL;}
  9     node(int id){idx=id;next=NULL;}
 10     int idx;
 11     node *next;
 12 }table[maxn];
 13 
 14 int a[100010][6];
 15 int n;
 16 int hash(int *a)
 17 {
 18     //a[6]=0;
 19     __int64 sum=0;
 20     for(int i=0;i<6;i++) sum+=a[i];//*a[i]);
 21     return sum%149997;
 22 }
 23 
 24 void init()
 25 {
 26     for(int i=0;i<n;i++){
 27         table[i].idx=-1;
 28         table[i].next=NULL;
 29     }
 30 }
 31 
 32 bool equal(int i,int j)
 33 {
 34     //if(a[i][6]!=a[j][6]) return false;
 35     int x,yy=0,y;
 36     int flag=0;
 37     while(yy<6){
 38         while(yy<6 && a[j][yy]!=a[i][0]) yy++;
 39         if(yy==6return false;
 40         y=yy;
 41         for(x=0;x<6;x++){
 42             if(a[i][x]==a[j][y]){
 43                 y++;
 44                 if(y==6) y=0;
 45             }
 46             else break;
 47         }
 48         if(x==6return true;
 49         y=yy;
 50         for(x=0;x<6;x++){
 51             if(a[i][x]==a[j][y]){
 52                 y--;
 53                 if(y==-1) y=5;
 54             }
 55             else break;
 56         }
 57         if(x==6return true;
 58         yy++;
 59     }
 60     return false;
 61 }
 62 
 63 // 讀入字符并轉成整數
 64 void readNumber(int i)
 65 {
 66     char ch;
 67     //ch=getchar();
 68     ch=getchar();
 69     while(ch==' ') ch=getchar();
 70     int x=0;
 71     while(ch!=' ') {x*=10;x+=ch-'0';ch=getchar();}
 72     a[i][0]=x;
 73 
 74     ch=getchar();
 75     while(ch==' ') ch=getchar();
 76     x=0;
 77     while(ch!=' ') {x*=10;x+=ch-'0';ch=getchar();}
 78     a[i][1]=x;
 79 
 80     ch=getchar();
 81     while(ch==' ') ch=getchar();
 82     x=0;
 83     while(ch!=' ') {x*=10;x+=ch-'0';ch=getchar();}
 84     a[i][2]=x;
 85 
 86     ch=getchar();
 87     while(ch==' ') ch=getchar();
 88     x=0;
 89     while(ch!=' ') {x*=10;x+=ch-'0';ch=getchar();}
 90     a[i][3]=x;
 91 
 92     ch=getchar();
 93     while(ch==' ') ch=getchar();
 94     x=0;
 95     while(ch!=' ') {x*=10;x+=ch-'0';ch=getchar();}
 96     a[i][4]=x;
 97 
 98     ch=getchar();
 99     while(ch==' ') ch=getchar();
100     x=0;
101     while(ch!=10 && ch!=' ')
102     {
103         x*=10;
104         x+=ch-'0';
105         ch=getchar();
106     }
107     a[i][5]=x;
108     if(ch==' '){
109         ch=getchar();
110         while(ch!=10) ch=getchar();
111     }
112 }
113 
114 bool solve()
115 {
116     scanf("%d",&n);
117     getchar();
118     //init();
119     int i,flag=0;
120     node *tmp,*tmp2;
121     for(i=0;i<&& !flag;i++){
122         //scanf("%d%d%d%d%d%d",&a[i][0],&a[i][1],&a[i][2],&a[i][3],&a[i][4],&a[i][5]);
123         readNumber(i);
124         int code=hash(a[i]);
125         if(table[code].idx==-1){
126             table[code].idx=i;
127         }else{
128             //flag=0;
129             tmp2=NULL;
130             tmp=&(table[code]);
131             while(tmp!=NULL){
132                 if(equal(i,tmp->idx)) {flag=1;break;}
133                 tmp2=tmp;
134                 tmp=tmp->next;
135             }
136             if(!flag) tmp2->next=new node(i);
137         }
138     }
139     //printf("%d\n",i);
140     /*
141     int aa,bb,cc,xx,yy,zz;
142     
143     if(i<n){
144         for(;i<n;i++) scanf("%d%d%d%d%d%d",&aa,&bb,&cc,&xx,&yy,&zz);
145     }
146     */
147     if(flag) return true;
148     return false;
149 }
150 
151 int main()
152 {
153     //freopen("in.txt","r",stdin);
154     if(solve()) printf("Twin snowflakes found.\n");
155     else printf("No two snowflakes are alike.\n");
156     return 1;
157 }
158 
159 
160 

posted on 2008-05-24 11:34 bon 閱讀(1110) 評論(1)  編輯 收藏 引用 所屬分類: Programming Contest

Feedback

# re: pku 3349 2009-06-24 17:07 sum
大哥超時 勒  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


Google PageRank 
Checker - Page Rank Calculator
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            开心色5月久久精品| 久久这里有精品视频| 亚洲精品国产欧美| 欧美国产精品人人做人人爱| 亚洲欧洲视频在线| 最新国产成人在线观看| 欧美日本一区| 性色av一区二区怡红| 香港久久久电影| 黄色一区二区在线观看| 免费不卡欧美自拍视频| 欧美大秀在线观看| 亚洲自拍高清| 欧美中文在线观看| 亚洲黄色片网站| 亚洲精品日韩激情在线电影| 国产精品久久久久免费a∨ | 久久人人97超碰精品888| 激情亚洲网站| 亚洲日本精品国产第一区| 国产精品美女在线观看| 久久这里只有精品视频首页| 欧美精品麻豆| 久久久一区二区| 欧美日韩精品久久久| 久久精品91久久香蕉加勒比| 欧美成人自拍视频| 欧美一级专区| 欧美极品一区| 久久精品国产在热久久| 欧美岛国激情| 久久久噜噜噜久久人人看| 欧美精品v日韩精品v韩国精品v | 亚洲国产成人av在线| 亚洲精品影视| 在线成人h网| 亚洲午夜影视影院在线观看| 在线观看一区二区精品视频| 一区二区三区免费网站| 亚洲电影在线看| 午夜视频一区| 亚洲欧美视频在线观看视频| 欧美福利一区| 久久免费高清| 国产麻豆视频精品| 99国产麻豆精品| 亚洲国产精品va在线看黑人动漫 | 亚洲精品自在在线观看| 精久久久久久| 欧美一区=区| 午夜影院日韩| 国产精品久久中文| 亚洲免费成人av| 亚洲精品视频中文字幕| 久久乐国产精品| 久久看片网站| 国产有码在线一区二区视频| 亚洲一区二区三区影院| 亚洲欧美成人一区二区三区| 欧美欧美天天天天操| 亚洲成人资源| 亚洲精品一区二区三区四区高清| 久久亚洲精品中文字幕冲田杏梨| 欧美专区第一页| 国产精品一区二区在线观看网站| 亚洲少妇在线| 午夜影院日韩| 国产日韩欧美91| 午夜精品婷婷| 久久五月激情| 亚洲国产精品悠悠久久琪琪| 久热精品视频在线观看一区| 欧美va亚洲va香蕉在线| 亚洲电影一级黄| 鲁大师成人一区二区三区| 欧美国产欧美综合| 亚洲免费黄色| 国产精品多人| 午夜精品美女自拍福到在线| 久久久99精品免费观看不卡| 韩国av一区二区三区在线观看| 久久黄金**| 亚洲大胆人体视频| 一区二区三区欧美亚洲| 国产精品麻豆成人av电影艾秋 | 蜜臀久久99精品久久久画质超高清| 好吊色欧美一区二区三区四区 | 午夜亚洲影视| 牛夜精品久久久久久久99黑人| 亚洲国产欧美一区二区三区同亚洲| 牛人盗摄一区二区三区视频| 99riav久久精品riav| 欧美一区二区视频在线观看2020 | 欧美美女bb生活片| 中文亚洲欧美| 久久综合婷婷| 这里是久久伊人| 国产一区日韩一区| 欧美高清视频在线播放| 亚洲女优在线| 亚洲国产精品成人| 欧美一区二区三区四区视频| 在线看片欧美| 国产精品美女久久久久av超清| 久久三级视频| 宅男噜噜噜66国产日韩在线观看| 久久精品一区二区三区不卡| 亚洲麻豆视频| 国产真实乱偷精品视频免| 欧美极品欧美精品欧美视频| 亚洲欧美在线免费| 亚洲破处大片| 可以看av的网站久久看| 亚洲一本大道在线| 在线日韩av片| 国产一区二区成人| 欧美色网在线| 欧美风情在线观看| 久久爱www久久做| 亚洲一区久久久| 亚洲人体影院| 欧美高清在线一区| 久久精品国产99国产精品| 一区二区欧美亚洲| 亚洲人成在线观看| 激情av一区二区| 国产欧美精品一区二区三区介绍| 欧美顶级大胆免费视频| 久久久水蜜桃av免费网站| 亚洲欧美一区二区三区极速播放| 亚洲三级视频在线观看| 欧美福利电影网| 久久亚洲精品中文字幕冲田杏梨 | 亚洲国产精品久久久久婷婷老年 | 亚洲欧洲视频| 亚洲国产女人aaa毛片在线| 国产亚洲欧美日韩日本| 国产精品欧美久久| 欧美亚州一区二区三区| 欧美日韩国产限制| 欧美人与禽猛交乱配| 欧美极品在线播放| 欧美国产专区| 欧美激情一区二区三区四区 | 9人人澡人人爽人人精品| 亚洲日本激情| 一区二区三区精品视频| 一区二区三区高清不卡| 一区二区精品在线| 亚洲性感激情| 欧美一区二视频在线免费观看| 亚洲欧美美女| 欧美在线播放视频| 久久在线播放| 欧美大片在线观看一区| 欧美精品七区| 国产精品豆花视频| 国产欧美日韩不卡| 红桃视频亚洲| 亚洲激情电影在线| 中文av字幕一区| 亚洲男人av电影| 久久久久久成人| 欧美成人a视频| 亚洲精品乱码久久久久久蜜桃麻豆 | 在线观看91精品国产入口| 伊人久久大香线| 亚洲精品一区二区三区婷婷月 | 美女脱光内衣内裤视频久久影院 | 亚洲欧美中文日韩v在线观看| 亚洲欧美日韩专区| 久久婷婷久久一区二区三区| 欧美承认网站| 国产精品免费视频xxxx| 韩国欧美一区| 中文久久精品| 久久精品综合一区| 亚洲国产高清在线| 亚洲一区在线播放| 快播亚洲色图| 国产精品毛片a∨一区二区三区|国 | 日韩视频一区二区| 羞羞视频在线观看欧美| 欧美夫妇交换俱乐部在线观看| 一区二区三区色| 久久在线观看视频| 国产精品乱码人人做人人爱| 亚洲精品1区| 久久99在线观看| 亚洲精品一线二线三线无人区| 香蕉久久夜色| 国产精品mm| 亚洲清纯自拍| 久久久久国产精品一区三寸| 一本色道久久综合| 免费观看成人鲁鲁鲁鲁鲁视频| 国产视频综合在线| 亚洲午夜国产成人av电影男同| 欧美成人性网| 久久成人人人人精品欧|