[U]3.1.5 Contact 小技巧题

刚开始做这题的时候思路错了, 把他想成字符串模式匹配题了。通过构建长度在[A,B]之间的字符串,然后再对主字符串进行模式匹配,想想要用kmp算法,对于这个我还不是很懂.... 打算好好学习一下kmp,后来估计了一下时间,发现必须超时。

转而一想:

其实需要的只是在主字符串中的一些子集,通过直接遍历主字符串长度为len(A<=len<=B),把这个数读出来,相应的+1就好。通过这种思路,写完代码。后发现,对于len=2,选项='00'和len=1,选项='0',都会被归为一类,明显这样不符合题意。

怎么解决呢?

可以通过添加前导'1',区别开来。再在输出的时候忽略前导'1'。

另外用到了排序,将出现频率分别开来。

输出的code写得不是很好;

/*
ID:sevenst4
LANG:C++
PROG:contact
*/
#include<stdio.h>
#include<algorithm>
using namespace std;

int cnt[10000];
int cp[10000];
char line[222222];

bool cmp( int a,int b ){ return a>b; };

void print( int num )
{
 	 int l=0;
 	 int k[15]={0};
 	 while( num )
 	 {
	  		k[l++]=num&1;
			num=num>>1;	
 	 }
 	 for( int i=l-2;i>=0;i-- )
 	 	  printf( "%d",k[i] );
}
int getnum( int s,int e )
{
 	int ret=0;
 	for( int i=s;i<e;i++ )
 		 if( line[i]=='1' )
 		 	 ret=ret<<1|1;
 		 else
 		 	 ret=ret<<1;
	return ret;
}

int main()
{
 	freopen( "contact.in","r",stdin );
 	freopen( "contact.out","w",stdout );
 	int A,B,N;
 	
 	for( int i=0;i<(1<<13);i++ ) cnt[i]=0;
 		 
 	scanf( "%d %d %d",&A,&B,&N );
 	
 	char data[80];
 	int len=0;
 	while( scanf( "%s",&data )!=EOF )
 	{
	 	   for( int i=0;data[i]!='\0';i++ )
	 	   		line[len++]=data[i];
    }
    
 	for( int i=A;i<=B;i++ )
 	{
	 	 for( int j=0;j+i<=len;j++ )
	 	 	  cnt[(1<<i)+getnum(j,j+i)]++;
	}
	
	for( int i=0;i<(1<<(B+1));i++ )
		 cp[i]=cnt[i];
		 
	sort( cp,cp+(1<<(B+1)),cmp );
	
	int index=0;
	while( N-- )
	{
	 	   int top=cp[index];
	 	   if( top==0 )
	 	   	   break;
  	       int outnum=0;
	 	   printf( "%d\n",top );
	 	   bool flag=false;
	 	   for( int i=0;i<(1<<(B+1));i++ )
	 	   		if( cnt[i]==top )
	 	   		{
	 	   			outnum++;
	 	   			if( outnum!=1 )
	 	   				printf( " " );//不是第一个有前导空格 
	 	   			print( i );
 	   				if( outnum==6 )//第六个有回车
					{
					 	outnum=0; 
	 	   				printf( "\n" );
					}
	 	   			index++;
				}
		   if( outnum!=0 )
		   	   printf( "\n" );
    }
 	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HDP 3.1.5是Hortonworks Data Platform(Hortonworks数据平台)的一个版本,Ubuntu是一个流行的开源操作系统,而Ambari 2.7.5是一个用于管理Hadoop集群的开源工具。 HDP 3.1.5是Hortonworks为大数据分析和处理提供的软件套件。它包括了一系列的开源组件,如Hadoop、Hive、HBase、Spark和Kafka等,可以用于存储和分析大规模数据。HDP 3.1.5版本带来了许多新功能和改进,提高了数据处理性能、安全性和可靠性。 Ubuntu是一个流行的开源操作系统,特点是易用性和稳定性。它支持HDP 3.1.5,并提供了包管理工具,方便用户安装和管理HDP的软件包。 Ambari 2.7.5是一个开源的集群管理工具,用于配置、监控和管理Hadoop集群。它提供了一个直观的Web界面,方便用户进行集群的配置和管理。Ambari 2.7.5版本为用户带来了更加稳定和高效的集群管理功能,并修复了一些bug。 结合使用HDP 3.1.5、Ubuntu和Ambari 2.7.5,用户可以方便地部署、配置和管理Hadoop集群。通过Ambari的直观界面,用户可以轻松监控集群的状态,并进行必要的配置和调整。Ubuntu作为操作系统,为HDP和Ambari提供了高度稳定和可靠的平台,确保集群正常运行。 总而言之,HDP 3.1.5提供了丰富的大数据处理工具,Ubuntu作为操作系统提供了稳定的平台,而Ambari 2.7.5则提供了集群管理的功能,使用户能够更方便地部署、配置和管理Hadoop集群。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值