你的硬盘上有一个神秘的文件占用了大量空间,你决定将其压缩以节省空间。不幸的是,你尚未安装任何压缩软件,因此你决定本身编写一个压缩程序。你发现这是一个文本文件,包括不少行。每行是一个长度刚好为L的字符串,并且字符串可能有重复。行的顺序并不重要,换言之,打乱顺序以后仍然能够认为文件内容和原来相同。ios
例如,这个文件的内容能够是这样的:json
barapi
car数组
bat框架
catpost
cat测试
通过一段时间观察,你发现同一列的字符每每是相同的,因而你设计了一个简单的压缩框架。首先以某种策略调整行的顺序,而后把全部字符串按照先列后行的顺序变换成单个字符串,例如上面的例子,不调整顺序则直接变换成:大数据
bcbccaaaaarrttt编码
而后使用游程编码(RLE)的到压缩变换后的字符串:spa
1b1c1b2c5a2r3t
固然也能够先调换顺序:
car
cat
cat
bat
bar
这样的压缩字符串为:
3c2b5a1r3t1r
比不调整顺序的稍短一些。
如今,你已经获得了两个不一样的压缩字符串,你想知道他们解压后的文件是否相同,请写一个程序解决这个问题。
第一行是一个整数T (T <= 30),表示测试数据组数。
每组测试数据占三行。第一行为整数L,表示原始文件中每一行字符串的长度。第二行和第三行分别是两个压缩字符串,格式如c1 n1 c2 n2 … cMnM,表示字符ci连续出现了ni次。具体格式见样例。输入字符串只含a到z的小写字母,确保压缩字符串合法有效,且不为空。
对每组测试数据,首先输出”Case x: ”,其中x表示测试数据编号。若是两个压缩字符串对应于相同的文件内容,则输出”Yes”,不然输出”No”。
小数据:1<=L<=10, 1<=ni<=100,压缩字符串长度不超过10^4
大数据:1<=L<=1000, 1<=ni<=10^9,压缩字符串长度不超过10^6
2 3 1b1c1b2c5a2r3t 3c2b5a1r3t1r 2 20a20b10a20b10a 20a20b20a20b
Case 1: Yes Case 2: No