zoukankan      html  css  js  c++  java
  • 编程之美挑战赛初赛第二场题目2

    时间限制:8000ms
    单点时限:4000ms
    内存限制:256MB

    描述
    你的硬盘上有一个神秘的文件占用了大量空间,你决定将其压缩以节省空间。不幸的是,你还没有安装任何压缩软件,所以你决定自己编写一个压缩程序。你发现这是一个文本文件,包括很多行。每行是一个长度恰好为L的字符串,而且字符串可能有重复。行的顺序并不重要,换言之,打乱顺序之后仍然可以认为文件内容和原来相同。

    例如,这个文件的内容可以是这样的:

    bar

    car

    bat

    cat

    cat

     
    经过一段时间观察,你发现同一列的字符往往是相同的,于是你设计了一个简单的压缩框架。首先以某种策略调整行的顺序,然后把所有字符串按照先列后行的顺序变换成单个字符串,例如上面的例子,不调整顺序则直接变换成:

    bcbccaaaaarrttt

    然后使用游程编码(RLE)的到压缩变换后的字符串:

    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

    代码如下:

    #include<vector>
    #include<iostream>
    #include<algorithm>
    #include<string>
    #include <stdlib.h>
    using namespace std;
    
    int main()
    {
    	int T,num=0;
    	cin>>T;
    	vector<string> okresult(T);
    	for(int i=0;i<T;++i)
    	{
    		int a,step;
    		int sum[2]={0,0};
    		vector<vector<string> > result(2);
    		vector<string> tep(2);
    		vector<string> tep1(2);
    		cin>>a;
    		cin>>tep[0];
    		cin>>tep[1];
    		for (int t=0;t<2;++t)
    		{
    			for (string::iterator st1=tep[t].begin();st1!=tep[t].end();++st1)
    			{
    				int count=0;
    				string ct1;
    				while('0'<=*st1&&*st1<='9')
    				{
    					ct1+=*(st1++);
    				}
    				count=atoi(ct1.c_str());
    				sum[t]+=count;
    				for (int j=count;j>0;--j)
    				{
    					tep1[t]+=*(st1);
    				}
    			}
    		}
    		
    
    		if (sum[0]==sum[1])
    		{
    			step=sum[0]/a;
    			string temp;
    			for (int t=0;t<2;++t)
    			{
    				for (int j=0;j<step;j++)
    				{
    					temp.clear();
    					for (int k=j;k<tep1[t].size();k+=step)
    					{
    						temp+=tep1[t][k];
    					}
    					//result[t].insert(temp);
    					result[t].push_back(temp);
    				}
    			}
    			sort(result[0].begin(),result[0].end());
    			sort(result[1].begin(),result[1].end());
    			if (result[0]==result[1])
    			{
    				//cout<<"Case "<<i+1<<": "<<"Yes"<<endl;
    				okresult[num++]="Yes";
    			}
    			else
    			{
    				//cout<<"Case "<<i+1<<": "<<"No"<<endl;
    				okresult[num++]="No";
    			}
    		}
    		else
    		{
    			//cout<<"Case "<<i+1<<": "<<"No"<<endl;
    			okresult[num++]="No";
    		}
    	}
    
    	for (int j=0;j<T;++j)
    	{
    		cout<<"Case "<<j+1<<": "<<okresult[j]<<endl;
    	}
    	system("pause"); 
    	return 0;
    }
    


     

  • 相关阅读:
    揭晓UX(用户体验)最大的秘密
    Js、jquery学习笔记
    网站建设之高速WEB的实现
    网站改版之指标分析
    Nodejs读写流
    Nodejs查找,读写文件
    网站建设之脚本加载
    如何利用CSS3编写一个满屏的布局
    如何设计自己的UI套件
    用requireJS进行模块化的网站开发
  • 原文地址:https://www.cnblogs.com/chhuach2005/p/3961703.html
Copyright © 2011-2022 走看看