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

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 閱讀(370) 評論(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>
            亚洲视频碰碰| 国内成人在线| 在线观看视频一区二区| 亚洲国产成人久久综合一区| 夜色激情一区二区| 免费成人高清| 久久一区二区三区四区五区| 黄色欧美成人| 久久中文字幕导航| 老司机久久99久久精品播放免费| 欧美日韩国产成人在线免费| 亚洲精选中文字幕| 亚洲日本在线观看| 欧美日本一区二区三区| 一本久久综合亚洲鲁鲁| 日韩视频在线观看| 欧美日韩一区二| 性欧美18~19sex高清播放| 亚洲欧美日韩综合aⅴ视频| 国产伦精品一区二区三区高清| 性欧美大战久久久久久久免费观看| 亚洲一区二区三区影院| 国产欧美在线视频| 久久综合色一综合色88| 欧美成人首页| 亚洲欧美另类在线观看| 欧美一区二区三区视频免费播放| 亚洲国产精品视频| 亚洲美女视频在线观看| 国产乱码精品一区二区三区不卡 | 久久人人看视频| 欧美gay视频激情| 亚洲欧美资源在线| 久久亚洲风情| 亚洲午夜一区二区三区| 亚洲在线1234| 亚洲精品在线视频| 欧美一区二区三区电影在线观看 | 免费在线观看日韩欧美| 亚洲你懂的在线视频| 久久综合色88| 欧美在线播放一区| 欧美成人午夜视频| 久久久久免费观看| 国产精品xvideos88| 欧美99久久| 国产精品社区| 日韩亚洲精品在线| 亚洲国产精品va| 欧美一区二区视频在线观看2020| 91久久精品一区二区三区| 亚洲一区国产| 亚洲人精品午夜在线观看| 亚洲视频第一页| 欧美日韩一区高清| 午夜精品福利一区二区蜜股av| 先锋a资源在线看亚洲| 精品动漫3d一区二区三区免费版| 99综合精品| 最新日韩精品| 久久精品亚洲精品国产欧美kt∨| 日韩一级二级三级| 久久婷婷激情| 欧美影院午夜播放| 欧美黄色视屏| 亚洲国产成人一区| 91久久精品国产91性色| 久久综合色播五月| 女人香蕉久久**毛片精品| 国产精品女主播在线观看| 亚洲精品日韩在线| 亚洲精品在线观看免费| 亚洲免费视频在线观看| 一本到高清视频免费精品| 久久成人在线| 欧美在线播放一区| 国产精品视频xxx| 欧美激情第1页| 国产精品三上| 欧美一区二区视频在线| 久久福利毛片| 国产欧美日韩视频在线观看| 亚洲一区二区四区| 午夜亚洲性色福利视频| 国产精品家教| 亚洲欧美一区二区原创| 久久黄金**| 国产亚洲午夜高清国产拍精品| 午夜精品久久久久| 久久精品国产96久久久香蕉| 欧美三区在线视频| 亚洲天堂第二页| 欧美一区二区免费观在线| 国产精品日本精品| 久久精品国产精品亚洲综合| 久久久久久久综合色一本| 狠狠色丁香婷婷综合| 久久亚洲精品欧美| 久久综合国产精品| 欧美一区2区三区4区公司二百| 国产色综合网| 亚洲一区二区精品在线| 欧美一区二区三区的| 国产精品成人一区二区艾草| 亚洲欧洲av一区二区三区久久| 久久精品一区中文字幕| 亚洲人成啪啪网站| 国产精品黄视频| 久久久99精品免费观看不卡| 欧美成人有码| 性欧美办公室18xxxxhd| 极品av少妇一区二区| 欧美激情视频在线播放| 亚洲欧美自拍偷拍| 亚洲风情在线资源站| 亚洲欧美成人| 国产一区二区三区在线播放免费观看 | 欧美顶级少妇做爰| 亚洲视频大全| 影音先锋日韩有码| 国产精品黄视频| 免费久久精品视频| 欧美成在线视频| 亚洲摸下面视频| 国产麻豆9l精品三级站| 欧美成人午夜激情在线| 一区二区欧美国产| 欧美福利电影网| 狠狠88综合久久久久综合网| 免费高清在线视频一区·| 美女爽到呻吟久久久久| 亚洲欧美日韩精品久久久久| 欧美日在线观看| 欧美成人一区二区三区在线观看 | 日韩亚洲成人av在线| 国产精品扒开腿爽爽爽视频| 久久一区亚洲| 日韩视频在线永久播放| 亚洲性图久久| 亚洲人www| 黄色精品一二区| 国产一区二区三区黄视频| 欧美午夜精品久久久久久人妖 | 欧美成人福利视频| 浪潮色综合久久天堂| 久久不射中文字幕| 久久久久女教师免费一区| 亚洲小说区图片区| 亚洲专区一二三| 午夜久久久久久| 亚洲欧美在线x视频| 亚洲欧美中文在线视频| 亚洲免费小视频| 欧美一区二区三区四区高清| 欧美一级在线播放| 午夜日韩福利| 久久精品人人爽| 欧美国产91| 亚洲国产一区二区三区高清| 亚洲免费电影在线| 亚洲六月丁香色婷婷综合久久| 一区二区三区四区五区视频| 亚洲人成在线观看一区二区| 亚洲天天影视| 亚洲日韩欧美视频一区| 亚洲自拍三区| 欧美一区二区三区在线观看视频| 欧美在线观看你懂的| 蜜桃久久精品一区二区| 欧美另类高清视频在线| 国产乱人伦精品一区二区| 韩日欧美一区二区| 一本色道久久综合精品竹菊| 亚洲先锋成人| 蜜臀av性久久久久蜜臀aⅴ四虎 | 在线中文字幕日韩| 亚洲精品国产视频| 久久丁香综合五月国产三级网站| 午夜天堂精品久久久久| 免费不卡在线视频| 亚洲国产欧美一区二区三区同亚洲| 日韩视频中文字幕| 久久久99爱| 欧美午夜欧美| 亚洲区一区二| 欧美一区二区视频在线| 最新中文字幕一区二区三区| 一本久久a久久免费精品不卡| 久久精品动漫| 欧美视频免费看| 亚洲精品免费观看| 久久se精品一区精品二区| 91久久视频| 日韩一区二区福利| 女同一区二区| 国产精品蜜臀在线观看| 亚洲精品视频在线看| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲欧洲精品成人久久奇米网| 久久久精品国产免费观看同学|