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

bon

  C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
  46 Posts :: 0 Stories :: 12 Comments :: 0 Trackbacks

常用鏈接

留言簿(2)

我參與的團(tuán)隊(duì)

搜索

  •  

最新評(píng)論

  • 1.?re: pku 1861
  • 評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
  • --edward2
  • 2.?re: pku 3349
  • 大哥超時(shí) 勒
  • --sum
  • 3.?re: pku 3070
  • 學(xué)習(xí)下,哇哈哈
  • --bear
  • 4.?re: poj 3340
  • 不用DFS的,直接有數(shù)學(xué)規(guī)律的,找出滿足條件的最小的數(shù)就可以了
  • --czcomt
  • 5.?re: pku 3070
  • 方法不錯(cuò)額~~~
  • --Zeor

閱讀排行榜

評(píng)論排行榜

poj 3349

本來(lái)不想看discuss了,不過(guò)因?yàn)檫@道題拖太久了,所以還是看了一下^_^,不過(guò)算法還是自己想的。
之前程序已經(jīng)做好了,但一直WA,估計(jì)不是算法的錯(cuò),而是程序的錯(cuò)。

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

2. 有大量輸入時(shí)(100000×6個(gè)整數(shù)),每個(gè)整數(shù)最長(zhǎng)有7位,這時(shí)用getchar()輸入字符再轉(zhuǎn)成整數(shù)會(huì)比scanf()輸入整數(shù)快很多!(2438ms VS 610ms)

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

  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 // 讀入字符并轉(zhuǎn)成整數(shù)
 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 閱讀(1105) 評(píng)論(1)  編輯 收藏 引用 所屬分類: Programming Contest

Feedback

# re: pku 3349 2009-06-24 17:07 sum
大哥超時(shí) 勒  回復(fù)  更多評(píng)論
  

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>
            久久精品一区蜜桃臀影院| 欧美视频导航| 欧美黄色日本| 欧美成人自拍视频| 欧美阿v一级看视频| 欧美成人精品不卡视频在线观看| 久久精品国产77777蜜臀| 久久精品av麻豆的观看方式| 久久国产主播精品| 美女黄网久久| 亚洲日韩欧美视频一区| 日韩视频精品在线| 香港成人在线视频| 久久欧美中文字幕| 欧美日韩精品欧美日韩精品一| 国产精品久久久久久亚洲毛片| 国产一区二区三区在线观看网站 | 亚洲国产精品视频| 一区二区三区|亚洲午夜| 午夜亚洲视频| 欧美成人午夜视频| 国产精品资源在线观看| 在线观看日韩av| 宅男精品视频| 久久久一本精品99久久精品66| 欧美成人免费全部| 亚洲淫性视频| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美日韩国产综合网| 伊人成人在线视频| 亚洲欧美视频在线| 亚洲国产精品激情在线观看| 亚洲性感激情| 麻豆9191精品国产| 国产欧美激情| 亚洲婷婷在线| 欧美激情五月| 欧美一级在线播放| 最新亚洲激情| 久久国产成人| 国产精品久久久久99| 亚洲欧洲三级电影| 久久久水蜜桃av免费网站| 99在线精品视频| 免费欧美在线视频| 一区二区在线视频播放| 欧美一区二区三区精品| 9色国产精品| 欧美激情精品久久久久久黑人 | 欧美中日韩免费视频| 亚洲人成艺术| 欧美成人第一页| 一区二区三区在线视频免费观看| 午夜精品久久久| 日韩视频在线免费| 欧美成人三级在线| 伊人久久久大香线蕉综合直播| 新片速递亚洲合集欧美合集| 日韩亚洲国产精品| 欧美精品久久久久久久| 91久久精品国产| 欧美黑人在线播放| 欧美成人免费在线视频| 亚洲人成绝费网站色www| 欧美成人自拍视频| 免费短视频成人日韩| 亚洲国产二区| 亚洲国产成人精品视频| 欧美激情视频免费观看| 亚洲人成人99网站| 亚洲国产精品一区二区第四页av| 久久久久久久97| 在线看片一区| 亚洲国产精品热久久| 欧美日本在线视频| 亚洲视频精品在线| 亚洲尤物在线| 韩国欧美国产1区| 欧美激情1区| 欧美日韩亚洲视频| 新67194成人永久网站| 久久精品72免费观看| 亚洲二区视频在线| 亚洲乱码视频| 国产日韩欧美三级| 欧美 日韩 国产 一区| 欧美—级a级欧美特级ar全黄| 一区二区三区黄色| 亚洲欧美日韩国产综合| 亚洲第一在线| 这里只有精品视频在线| 韩日欧美一区二区三区| 亚洲国产美女精品久久久久∴| 国产精品v欧美精品v日韩 | 久久午夜羞羞影院免费观看| 亚洲大片一区二区三区| 亚洲精品影视| 国产专区综合网| 亚洲精品一区二区三区av| 国产精品亚洲аv天堂网| 久久躁狠狠躁夜夜爽| 欧美人与禽猛交乱配视频| 久久久97精品| 欧美日精品一区视频| 久久一区二区三区av| 欧美日韩精品欧美日韩精品| 久久久久成人网| 欧美区一区二区三区| 久久中文字幕一区| 国产精品成av人在线视午夜片| 免费不卡中文字幕视频| 国产精品亚洲欧美| 最新日韩在线视频| 在线免费观看日本欧美| 亚洲一区免费看| 99精品欧美一区二区三区| 久久久www成人免费精品| 一区二区久久久久| 你懂的视频欧美| 久久免费精品日本久久中文字幕| 欧美日韩一区三区| 亚洲国产一区二区在线| 伊人天天综合| 欧美在线视频观看免费网站| 亚洲综合社区| 欧美日韩一区二区欧美激情 | 久热re这里精品视频在线6| 国产精品久久久久毛片软件| 91久久国产综合久久91精品网站| 激情欧美国产欧美| 欧美一区三区二区在线观看| 午夜精品亚洲| 国产精品高清网站| 一本一本久久| 亚洲网站在线观看| 欧美日韩久久不卡| 日韩午夜在线视频| 在线视频精品一区| 欧美三级电影大全| 一二三区精品| 亚洲欧美在线视频观看| 国产精品毛片va一区二区三区| 一区二区三区视频观看| 亚洲永久字幕| 国产麻豆精品久久一二三| 亚洲欧美精品中文字幕在线| 香蕉精品999视频一区二区| 国产日韩欧美自拍| 久久高清免费观看| 欧美大尺度在线观看| 亚洲精品久久久蜜桃| 欧美日韩国产电影| 亚洲午夜精品视频| 久久免费精品日本久久中文字幕| 尤物九九久久国产精品的分类| 久久资源av| 亚洲黄色影片| 亚洲欧美视频| 激情五月***国产精品| 久久人人九九| 亚洲日产国产精品| 国产精品视频yy9299一区| 亚洲视频自拍偷拍| 久久av在线看| 亚洲二区三区四区| 欧美日韩国产成人| 亚洲欧美一级二级三级| 麻豆精品传媒视频| 夜夜嗨av一区二区三区| 国产精品一卡二| 久久综合给合久久狠狠狠97色69| 亚洲激情视频网| 久久成人一区二区| 91久久精品日日躁夜夜躁国产| 欧美日韩视频第一区| 欧美一区二区三区播放老司机| 欧美高清一区二区| 香蕉久久夜色| 亚洲精品欧美日韩专区| 国产精品一区二区三区乱码| 久久夜色精品| 亚洲欧美日韩精品在线| 亚洲国产日韩在线| 久久久精彩视频| 一区二区三区www| 精品动漫av| 国产精品视频一区二区三区| 欧美11—12娇小xxxx| 欧美一区成人| 99精品国产热久久91蜜凸| 久久人人爽人人爽爽久久| 亚洲视频电影图片偷拍一区| 一色屋精品视频在线观看网站| 欧美日本韩国一区二区三区| 久久福利一区| 亚洲欧美日本另类| 亚洲最新在线| 亚洲精品视频免费观看| 欧美福利在线| 美女图片一区二区|