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

USACO 3.1 Contact


字符串的長度有限(最多只有12位),我建一個trie樹來存儲所有字符串,然后遍歷trie樹,將對應的字符串存儲到一個vector中,再排序輸出。
ac以后,看usaco的分析,是用位串來做索引計數,這種方法比較簡潔巧妙。為了解決前綴為0的問題,在每個字符串前面加了一個1,輸出的時候再去掉。
我的解法如下:

#include?<iostream>
#include?
<fstream>
#include?
<vector>
#include?
<string>

using?namespace?std;

ifstream?fin(
"contact.in");
ofstream?fout(
"contact.out");

#ifdef?_DEBUG
#define?out?cout
#define?in?cin
#else
#define?out?fout
#define?in?fin
#endif

struct?trie_node{
????
int?cnt;
????trie_node
*?sons[2];
????trie_node(){
????????sons[
0]?=?sons[1]?=?0;
????????cnt?
=?0;
????}
};

struct?sort_node{
????
string?str;
????
int?cnt;

????
bool?operator<(const?sort_node&n2)?const{
????????
if(cnt!=n2.cnt)?return?cnt>n2.cnt;
????????
if(str.size()!=n2.str.size())?return?str.size()<n2.str.size();
????????
for(int?i=0;i<str.size();++i){
????????????
if(str[i]!=n2.str[i])
????????????????
return?str[i]<n2.str[i];
????????}
????}
};

char?buf[200000];
int?buf_len;
int?a,b,n;
vector
<sort_node>res;

void?insert_trie(trie_node*root,const?char?*start,int?len)
{
????trie_node?
*?next?=?root;

????
for(int?i=0;i<len;++i){
????????
if(next->sons[start[i]-'0']==NULL)
????????????next
->sons[start[i]-'0']?=?new?trie_node;
????????next?
=?next->sons[start[i]-'0'];
????????
if(i+1>=a&&i+1<=b)
????????????next
->cnt++;
????}
}

void?_traverse_trie(trie_node?*root,char?ch,int?depth)
{
????
if(root==NULL)?return;

????buf[depth]
=ch;

????
if(root->cnt!=0){
????????sort_node?n;
????????n.str?
=?string(&buf[0],&buf[depth+1]);
????????n.cnt?
=?root->cnt;
????????res.push_back(n);
????}

????_traverse_trie(root
->sons[0],'0',depth+1);
????_traverse_trie(root
->sons[1],'1',depth+1);
}

void?traverse_trie(trie_node?*root)
{
????_traverse_trie(root
->sons[0],'0',0);
????_traverse_trie(root
->sons[1],'1',0);
}


void?solve()
{
????
in>>a>>b>>n;

????
char?ch;
????
while(in.get(ch)){
????????
if(ch=='0'||ch=='1')
????????????buf[buf_len
++]?=?ch;
????}

????trie_node?root;

????
for(int?i=0;i+b<=buf_len;++i){
????????insert_trie(
&root,&buf[i],b);
????}

????
for(int?i=min(b-1,buf_len);i>=a;--i){
????????insert_trie(
&root,&buf[buf_len-i],i);
????}

????traverse_trie(
&root);

????sort(res.begin(),res.end());

????
int?freq_cnt?=?0;
????
int?last_cnt?=?-1;
????
int?out_cnt?=?0;

????
for(int?i=0;i<res.size();++i){
????????
if(res[i].cnt==last_cnt){
????????????
if(out_cnt%6!=0)
????????????
out<<"?";
????????????
out<<res[i].str;
????????????out_cnt
++;
????????????
if(out_cnt%6==0||i==(res.size()-1)||res[i+1].cnt!=res[i].cnt)
????????????????
out<<endl;
????????}
else{
????????????last_cnt?
=?res[i].cnt;
????????????freq_cnt
++;
????????????
if(freq_cnt>n)
???????????????
break;?
????????????
out<<res[i].cnt<<endl;
????????????
out<<res[i].str;
????????????out_cnt?
=?0;
????????????out_cnt
++;
????????????
if(?(i==res.size()-1)||res[i+1].cnt!=res[i].cnt)
????????????????
out<<endl;
????????}
????}
}

int?main(int?argc,char?*argv[])
{
????solve();?
????
return?0;
}


附題:
Contact
IOI'98

The cows have developed a new interest in scanning the universe outside their farm with radiotelescopes. Recently, they noticed a very curious microwave pulsing emission sent right from the centre of the galaxy. They wish to know if the emission is transmitted by some extraterrestrial form of intelligent life or if it is nothing but the usual heartbeat of the stars.

Help the cows to find the Truth by providing a tool to analyze bit patterns in the files they record. They are seeking bit patterns of length A through B inclusive (1 <= A <= B <= 12) that repeat themselves most often in each day's data file. They are looking for the patterns that repeat themselves most often. An input limit tells how many of the most frequent patterns to output.

Pattern occurrences may overlap, and only patterns that occur at least once are taken into account.

PROGRAM NAME: contact

INPUT FORMAT

Line 1: Three space-separated integers: A, B, N; (1 <= N < 50)
Lines 2 and beyond: A sequence of as many as 200,000 characters, all 0 or 1; the characters are presented 80 per line, except potentially the last line.

SAMPLE INPUT (file contact.in)

2 4 10
01010010010001000111101100001010011001111000010010011110010000000

In this example, pattern 100 occurs 12 times, and pattern 1000 occurs 5 times. The most frequent pattern is 00, with 23 occurrences.

OUTPUT FORMAT

Lines that list the N highest frequencies (in descending order of frequency) along with the patterns that occur in those frequencies. Order those patterns by shortest-to-longest and increasing binary number for those of the same frequency. If fewer than N highest frequencies are available, print only those that are.

Print the frequency alone by itself on a line. Then print the actual patterns space separated, six to a line (unless fewer than six remain).

SAMPLE OUTPUT (file contact.out)

23
00
15
01 10
12
100
11
11 000 001
10
010
8
0100
7
0010 1001
6
111 0000
5
011 110 1000
4
0001 0011 1100

posted on 2009-07-02 22:07 YZY 閱讀(380) 評論(0)  編輯 收藏 引用 所屬分類: AlgorithmUSACO

導航

<2009年7月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

統計

常用鏈接

留言簿(2)

隨筆分類

隨筆檔案

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一区二区视频在线| 久久露脸国产精品| 亚洲人成在线播放| 免费视频一区| 最近中文字幕mv在线一区二区三区四区| 毛片基地黄久久久久久天堂| 欧美一区亚洲一区| 激情婷婷欧美| 欧美激情在线观看| 欧美另类一区| 亚洲欧美在线网| 欧美一区二区三区在线免费观看| 国产一区二区精品久久| 老司机一区二区| 欧美国产日产韩国视频| 宅男噜噜噜66一区二区| 中文亚洲字幕| 激情综合激情| 最新成人av在线| 国产精品国产福利国产秒拍| 欧美一区亚洲一区| 快播亚洲色图| 亚洲一区视频在线| 黑人巨大精品欧美一区二区| 久久久久久9999| 欧美电影打屁股sp| 午夜激情亚洲| 久久尤物视频| 午夜精品久久久99热福利| 欧美在线免费观看视频| 日韩一级片网址| 亚洲欧美国产va在线影院| 91久久综合| 亚洲欧洲av一区二区三区久久| 亚洲国产精品电影| 亚洲尤物在线| 亚洲精选在线| 欧美伊久线香蕉线新在线| 一区二区免费看| 久久九九国产精品怡红院| 亚洲免费伊人电影在线观看av| 久久精品91久久久久久再现| 一本一本久久| 免费h精品视频在线播放| 香蕉乱码成人久久天堂爱免费| 另类av一区二区| 欧美专区在线观看一区| 欧美日韩精品二区| 欧美国产精品人人做人人爱| 国产日韩欧美视频| 一区二区激情视频| 亚洲精品免费一区二区三区| 欧美一区影院| 欧美中文字幕在线播放| 欧美日韩视频一区二区| 欧美岛国激情| 狠狠色综合播放一区二区| 亚洲在线观看免费视频| 亚洲精品美女在线| 欧美成人免费观看| 欧美成人精品三级在线观看| 国产麻豆视频精品| 亚洲性感激情| 亚洲女优在线| 国产精品第13页| 99在线热播精品免费| 一区二区三区四区五区视频| 欧美精品福利| 亚洲日本无吗高清不卡| 日韩午夜在线电影| 女人香蕉久久**毛片精品| 欧美成人激情视频| 亚洲第一搞黄网站| 另类人畜视频在线| 欧美激情精品久久久久久变态| 国产综合色产在线精品| 性8sex亚洲区入口| 久久在线91| 亚洲成人在线视频播放| 欧美xx视频| 日韩天堂av| 午夜视黄欧洲亚洲| 国产欧美日韩精品丝袜高跟鞋 | 国产日韩精品一区二区三区| 一区二区三区四区精品| 亚洲欧美日本日韩| 国产欧美日韩综合一区在线播放| 性一交一乱一区二区洋洋av| 久久久久久久久蜜桃| 亚洲盗摄视频| 欧美日韩国产精品自在自线| 亚洲无亚洲人成网站77777| 欧美夜福利tv在线| 影音先锋国产精品| 欧美国产日韩xxxxx| 亚洲视频精品在线| 久久另类ts人妖一区二区| 亚洲国产精品美女| 欧美日韩亚洲另类| 午夜一区在线| 亚洲国产精品传媒在线观看| 亚洲一区二区视频| 国内揄拍国内精品少妇国语| 六月婷婷久久| 亚洲色图在线视频| 免费观看不卡av| 在线亚洲自拍| 在线观看亚洲精品| 欧美日韩综合不卡| 久久婷婷国产综合尤物精品| 日韩一级精品视频在线观看| 久久精品中文字幕一区| 日韩视频免费观看高清在线视频| 国产精品看片你懂得| 久色婷婷小香蕉久久| 亚洲已满18点击进入久久| 欧美成年人视频| 亚洲欧美欧美一区二区三区| 亚洲福利在线看| 国产精品推荐精品| 欧美日韩国产成人在线观看| 久久动漫亚洲| 亚洲午夜久久久久久久久电影网| 免费在线观看精品| 久久福利资源站| 亚洲视频在线观看三级| 亚洲欧洲精品成人久久奇米网| 国产欧美精品国产国产专区| 欧美日本一区二区高清播放视频| 久久精品午夜| 欧美一级夜夜爽| 亚洲视频综合| 99视频一区二区| 亚洲人成7777| 亚洲国产小视频| 欧美成人免费小视频| 久久国产主播| 欧美在线视频一区二区| 亚洲一区欧美一区| 在线综合+亚洲+欧美中文字幕| 亚洲国产日本| 亚洲国产一区视频| 亚洲福利国产| 亚洲人久久久| 亚洲精品乱码久久久久久蜜桃91| 亚洲国产精品第一区二区| 精品电影在线观看| 红桃视频成人| 在线观看视频一区二区| 禁久久精品乱码| 韩国女主播一区二区三区| 国模一区二区三区| 激情综合网址| 亚洲福利视频一区| 亚洲人成在线观看一区二区| 亚洲精品久久久久久久久久久久久 | 午夜视频一区在线观看| 亚洲一区二区三区免费视频| 亚洲天堂激情| 欧美一区二区视频观看视频| 欧美在线欧美在线| 久久精品人人做人人爽电影蜜月 | 亚洲国内高清视频| 亚洲国产精品专区久久| 亚洲精品久久久久久久久| 日韩午夜激情av| 亚洲小说区图片区| 久久精品国产2020观看福利| 久久婷婷国产综合精品青草| 欧美不卡激情三级在线观看| 欧美日韩一区二| 国产精品自拍小视频| 黄色免费成人| 亚洲美女性视频| 欧美一区二区精品久久911| 久久久久久久综合色一本| 欧美黄色免费| 在线综合亚洲| 久久久久久久综合色一本| 欧美日本视频在线| 国产亚洲一区在线播放| 亚洲国产成人在线| 亚洲欧美另类国产| 欧美波霸影院| 一本色道久久综合亚洲精品高清| 性伦欧美刺激片在线观看| 欧美激情成人在线| 国产亚洲美州欧州综合国| 亚洲国产日韩综合一区| 亚洲欧美中文在线视频| 免播放器亚洲一区| 中文日韩在线| 欧美电影专区| 国产欧美三级| 国产精品99久久久久久人| 久久人人97超碰精品888| 99在线热播精品免费99热| 可以免费看不卡的av网站| 国产精品人人爽人人做我的可爱| 亚洲国产婷婷|