USACO 3.1.5 Contact
来源:互联网 发布:java sleep和wait区别 编辑:程序博客网 时间:2024/06/10 12:37
分析:1、如何区分0,00,000,0000...等等 2、当出现的次数相同时,字符串的输出顺序(先输出短的在输出长的,一样长时先输出小的,在输出大的)。解决这两个问题最直接的办法就是在字符串前面加一个1,这样就可以根据大小来区分0,00,000,0000等;而短的字符串在前面加1自然没有长的字符串在前面加1数字大,所以也区分开了。
源代码:
/*ID: supersnow0622PROG: contactLANG: C++*/#include <iostream>#include <fstream>#include <string>#include<memory.h>#include<algorithm>using namespace std;struct Node{ int Count,index; char str[14];};Node n[20000];int used[20000];int cmp(Node n1,Node n2){ if(n1.Count==n2.Count) return n1.index<n2.index; else return n2.Count<n1.Count;}int main() { ofstream fout ("contact.out"); ifstream fin ("contact.in"); int A,B,N; string s,temp; int count,num; cin>>A>>B>>N; getline(cin,temp); while(getline(cin,temp)) s+=temp; if(s.length()<B)B=s.length(); for(int i=A;i<=B;i++) for(int j=0;j<s.length()-i+1;j++) { int count=0;num=1; while(count<i) { num=num<<1; num=num|(int)(s[j+count]-'0'); count++; } n[num].Count++; if(n[num].Count==1){ n[num].index=num; for(int k=0;k<i;k++) n[num].str[k]=s[k+j]; } } sort(n,n+20000,cmp); memset(used,0,sizeof(used)); bool judge=true;count=0; for(int i=0;i<20000;i++) { if(n[i].Count!=0){ if(!used[n[i].Count]) { count++;num=1; if(count>N)break; if(!judge)cout<<endl;judge=false; cout<<n[i].Count<<endl<<n[i].str; used[n[i].Count]=1; } else{ if(num%6==0)cout<<endl<<n[i].str; else cout<<" "<<n[i].str;num++; } } } return 0;}
- USACO 3.1.5 Contact
- USACO 3.1.5 Contact
- USACO 3.1.5 Contact
- [USACO]3.1.5 Contact
- USACO 3.1 Contact (contact)
- USACO 3.1 Contact
- usaco 3.1 Contact
- usaco 3.1 Contact
- USACO--3.1Contact
- usaco 3.1 Contact
- USACO-Section 3.1-PROB Contact
- usaco 3.1 contact 2008.7.18
- usaco contact
- usaco Contact
- USACO-Contact
- usaco contact
- usaco Chapter 3 section 3.1 Contact
- USACO Section 3.1 Contact - AC自动机..
- Android 无法接收开机广播的问题
- Singleton 单例模式
- ffmpeg开发指南
- 部署DNS管理工具--namedmanager
- 《乌合之众》读书笔记
- USACO 3.1.5 Contact
- 形态学处理方法总结
- VirtualBox SSH 登录 NAT 方式联网的 GUEST HOST
- Eclipse实用插件
- hdu题目分析(简介)
- 关于前置摄像头拍照后照片方向的总结(续前篇)
- matcher 的group
- PHP汉字拼音转换和公历农历转换
- 由金山WPS中标央企采购大单想到的