#include <iostream>

using namespace  std;

#define  SIZE 9
#define  MAXLEN  6

int data[SIZE][MAXLEN];
int numberLen[SIZE];
int overlapLen[SIZE+1][SIZE+1];

void IToA(int N ,int row)   //数字转换为数组
{
	int tmp=N;
	int i=0;
	while(tmp)
	{
		i++;
		tmp/=10;
	}
	numberLen[row]=i;
	tmp=N;
	for(int j=i-1;j>=0;j--)
	{
		data[row][j]=tmp%10;
		tmp/=10;
	}
}

void getOverlapLen(int i,int j)  //计算两个数字的最小重叠长度
{
	for(int len=1;len<=numberLen[i]&&len<=numberLen[j];len++)
	{
		int match=1;
		for(int m=numberLen[i]-len,n=0;m<numberLen[i]&&n<numberLen[j];m++,n++)
		{
			if(data[i][m]!=data[j][n])
			{
				match=0;
				break;
			}
		}

		if(match)
		{
			overlapLen[i][j]=len;
			break;
		}
	}
}

int maxLen=0;
int used[SIZE];

void getMaxLen(int step ,int numbers,int curlen,int remainingLen,int preNumber)
{
	if(step==numbers)
		return ;
	if(curlen+remainingLen-numbers+step+1<=maxLen)
		return;

	for(int i=0;i<numbers;i++)
	{
		if(!used[i])
		{
			used[i]=1;
			int tmpLen=curlen;

			if(overlapLen[i][preNumber]==0&&step!=0)    //连接成功
			{
				used[i]=0;
				continue;
			}	

			curlen+=numberLen[i]-overlapLen[i][preNumber];
			if(maxLen<curlen)
				maxLen=curlen;
			getMaxLen(step+1,numbers,curlen,remainingLen-numberLen[i],i);

			used[i]=0;
			curlen=tmpLen;

		}
	}
}

void main()
{
	//freopen("in.txt","r",stdin);
	int nTc;
	cin>>nTc;
	for(int tc=0;tc<nTc;tc++)
	{
		int N;
		cin>>N;
		maxLen=0;
		for(int i=0;i<N;i++)
		{
			used[i]=0;
			for(int j=0;j<N;j++)
			{
				data[i][j]=0;
				overlapLen[i][j]=0;
			}
		}

		int temp;
		int totalLen=0;
		for(int i=0;i<N;i++)
		{
			cin>>temp;
			IToA(temp,i);
			totalLen+=numberLen[i];

		}

		for(int i=0;i<N;i++)
		{
			for(int j=0;j<N;j++)
			{
				if(i!=j)
				getOverlapLen(i,j);
			}
		}

		getMaxLen(0,N,0,totalLen,SIZE);
		cout<<maxLen<<endl;
	}
}

ADV数字的剪切的更多相关文章

  1. vim基本命令之剪切复制粘贴替换

    首先是剪切(删除): 剪切其实也就顺带删除了所选择的内容,所以既可以当剪切命令用,也可以当删除命令使用. 1 首先,可以在命令模式下输入v进入自由选取模式,选择需要剪切的文字后,按下d就可以进行剪切了 ...

  2. vim命令的妙用

    进来看到了一篇博文,讲述的是无插件Vim编程技巧,然后看到里面还有一些其余的关于vim的博文,感觉值得收藏:酷 壳 – CoolShell.cn 这里挑选出其中一篇,这也是自己已经学习过的: 无插件V ...

  3. 无插件Vim编程技巧

    无插件Vim编程技巧 http://bbs.byr.cn/#!article/buptAUTA/59钻风 2014-03-24 09:43:46 发表于:vim  相信大家看过<简明Vim教程& ...

  4. vim复制

    关于vim复制剪贴粘贴命令的总结   最近在使用vim,感觉很好很强大,但是在使用复制剪切粘贴命令是,碰到了一些小困惑,网上找了一些资料感觉很不全,讲的也不好,遂自己进行实践并总结了. 首先是剪切(删 ...

  5. 无插件VIM编程技巧(网摘)

    无插件VIM编程技巧 原文出处:[陈皓 coolshell] 相信大家看过<简明Vim教程>也玩了<Vim大冒险>的游戏了,相信大家对Vim都有一个好的入门了.我在这里把我日常 ...

  6. vim编辑

    vim 重点在于光标的移动,模式的切换,删除,查找,替换,复制,黏贴,撤销命令的使用 vim的三种模式:命令模式(打开文件默认进入此模式)编辑模式(输入模式)末行模式(按:键进入,只能从命令模式下按键 ...

  7. vim 命令补充(1)

    本篇文章主要教你如何使用 Vim 分屏功能. 分屏启动Vim 使用大写的O参数来垂直分屏. vim -On file1 file2 ... 使用小写的o参数来水平分屏. vim -on file1 f ...

  8. vi 使用小结

    复制 1,ny 从哪行到哪行的复制,中间用逗号隔开,然后命令y. 黏贴 是在命令模式下直接按p即可 跳到n行: 命令模式直接输入数字即可 剪切:d命令 删除:x命令 跳到行首行尾:直接home或end ...

  9. liunx基础命令

    linux的简单介绍 linux是一款免费使用和自由传播的内似于unix的操作系统软件,是一个基于POSI和unix的多用户,多任务,支持多线程和多CPU的一种操作系统.主要用于服务器,特别是网络服务 ...

随机推荐

  1. HttpResponseMessage和HttpResponseException (转)

    Web API 中提供了 HttpResponseMessage 与 HttpResponseException 用于处理返回讯息,HttpResponseMessage 用于返回一个来自于客户端的请 ...

  2. Foundation ----->NSArray

    .数组的创建     //注意:在OC的数组中,只能够存放对象 //    NSArray *array = [NSArray arrayWithObject:12];错误          //创建 ...

  3. C#绘制传感器代码

    //以下代码添加到任一窗口下即可        private int 旋转角度 = 0;        private int 边长 = 10;        protected override ...

  4. centos7.2环境elasticsearch-5.0.1+kibana-5.0.1+zookeeper3.4.6+kafka_2.9.2-0.8.2.1部署详解

    centos7.2环境elasticsearch-5.0.1+kibana-5.0.1+zookeeper3.4.6+kafka_2.9.2-0.8.2.1部署详解 环境准备: 操作系统:centos ...

  5. 关于js作用域链,以及闭包中的坑

    eg:链式作用域,想在外部读取blogName的值得方法 <script>var authorName="山边小溪";function doSomething(){   ...

  6. iOS图片编辑功能实现

    图片加标签:标签可以编辑 https://github.com/shumingli/waterMark 1. 编辑效果;图片可以放到.缩小.旋转 2. 保存相册效果

  7. 我读汤姆大叔的深入理解js(一)

    前言 闲来看看javascript,在圆子里发现了汤姆大叔的文章,先是整体瞄了几眼,感觉不错,然后细细研读.记录下自己的学习历程和个人理解.更重要的是作为笔记 高质量JS代码 在看汤姆大叔的这一系列文 ...

  8. vim 大全用法

    vim中常用设置和操作: 在Linux系统下: 打开vi 文件: 0 数字0,跳转至行首    ^ 跳转至行第一个非空字符    $ 跳转至行尾 vim 括号匹配跳转操作: ctrl+] 跳转至函数或 ...

  9. jsp与数据库的连接

    经过一段时间的学习与上网查资料,我已经成功的用java语言连接上了数据库, 本以为同理jsp跟数据库的连接肯定水到渠成的,但是在经过尝试很多次后我发现现实永远是骨感的,最终结果是花了一个下午的时间去建 ...

  10. table变色

    <!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...