nyoj 628 小媛在努力 【搜索】

第一次是直接建一个10^7的数组 结果  内存大的要死!!

是不是可以不建数组 这下好了

小媛在努力

时间限制:1000 ms  |  内存限制:65535 KB

难度:2

描述
在多媒体数据处理中,数据压缩算法尤为重要。小媛上完课后就想自己发明一个数据压缩算法。她想呀想,终于想到一个方法。在多媒体数据中有很多数据都是重复的,所以她想把连续相同的数据用数据出现的次数和数据本身表示。例如:1 1 1 2 3 3 3 3 3  压缩后及为3 1 1 2 5 3(表示3个1,1个2和5个3)。有想法后小媛就希望把它用代码实现了。但是大家都知道小媛现在整天都忙着苦B的复习考研,连电脑都摸不到。所以她希望作为ACMer的你帮她写一下。

输入
输入包含多组数据,第一行一个数字T代表输入样例数。

每组样例开始一个数M < 10^7表示这组数据中数字的个数,接下来M个数表示要被压缩的数字(数字都不超过int表示的范围)。

输出
每组测试数据输出一行数字对,如上面描述的一样。两个数字之间用一个空格隔开。
样例输入
1
9 1 1 1 2 3 3 3 3 3 
样例输出
3 1 1 2 5 3 
第一次的代码:
<span style="font-family:Consolas, Courier New, DejaVu Sans Mono, Droid Sans Mono, monospace;color:#464646;"><span style="font-size: 14px; line-height: 1.5em;">
</span></span><pre name="code" class="cpp">#include<stdio.h>
int a[10000005];
int main()
{
	int t, n, i, count;
	scanf( "%d", &t );
	while( t -- )
	{
		count = 1;
		scanf( "%d", &n );
		for( i = 0; i < n; i ++ )
		scanf( "%d", &a[i] );
		for( i = 1; i < n; i ++ )
		{
			if( a[i]==a[i-1] )
			++count;
			else
			{
				printf( "%d %d ", count, a[i-1] );
				count = 1;
			}
		}
		if( a[n-1] == a[n-2] )
		printf( "%d %d\n", count, a[n-1] );
		else
		printf( "1 %d\n", a[n-1] );
	}
}    

第二次的<pre name="code" class="cpp">
#include<stdio.h>
int main()
{
	int n, t, a, b, c, i;
	scanf( "%d", &t );
	while( t -- )
	{
		scanf( "%d", &n );
		scanf( "%d", &a );
		c = 1;
		for( i = 1; i < n; i ++ )
		{
			scanf( "%d", &b );
			if( b == a )
			++c;
			else
			{
				printf( "%d %d ", c, a );
				a = b;
				c = 1;
			}
		}
		 printf( "%d %d\n", c, a );
	}
}        


nyoj 628 小媛在努力 【搜索】

时间: 2024-10-06 13:38:20

nyoj 628 小媛在努力 【搜索】的相关文章

NYOJ 628 小媛在努力

小媛在努力 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 在多媒体数据处理中,数据压缩算法尤为重要.小媛上完课后就想自己发明一个数据压缩算法.她想呀想,终于想到一个方法.在多媒体数据中有很多数据都是重复的,所以她想把连续相同的数据用数据出现的次数和数据本身表示.例如:1 1 1 2 3 3 3 3 3  压缩后及为3 1 1 2 5 3(表示3个1,1个2和5个3).有想法后小媛就希望把它用代码实现了.但是大家都知道小媛现在整天都忙着苦B的复习考研,连电脑都摸不到

NYOJ小媛在努力

小媛在努力 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 在多媒体数据处理中,数据压缩算法尤为重要.小媛上完课后就想自己发明一个数据压缩算法.她想呀想,终于想到一个方法.在多媒体数据中有很多数据都是重复的,所以她想把连续相同的数据用数据出现的次数和数据本身表示.例如:1 1 1 2 3 3 3 3 3  压缩后及为3 1 1 2 5 3(表示3个1,1个2和5个3).有想法后小媛就希望把它用代码实现了.但是大家都知道小媛现在整天都忙着苦B的复习考研,连电脑都摸不到

小媛在努力

小媛在努力 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 在多媒体数据处理中,数据压缩算法尤为重要.小媛上完课后就想自己发明一个数据压缩算法.她想呀想,终于想到一个方法.在多媒体数据中有很多数据都是重复的,所以她想把连续相同的数据用数据出现的次数和数据本身表示.例如:1 1 1 2 3 3 3 3 3  压缩后及为3 1 1 2 5 3(表示3个1,1个2和5个3).有想法后小媛就希望把它用代码实现了.但是大家都知道小媛现在整天都忙着苦B的复习考研,连电脑都摸不到

NYOJ-682 小媛在努力 (郑大第六届校赛 模拟)

链接:click here 题意: 描述 在多媒体数据处理中,数据压缩算法尤为重要.小媛上完课后就想自己发明一个数据压缩算法.她想呀想,终于想到一个方法.在多媒体数据中有很多数据都是重复的,所以她想把连续相同的数据用数据出现的次数和数据本身表示.例如:1 1 1 2 3 3 3 3 3  压缩后及为3 1 1 2 5 3(表示3个1,1个2和5个3).有想法后小媛就希望把它用代码实现了.但是大家都知道小媛现在整天都忙着苦B的复习考研,连电脑都摸不到.所以她希望作为ACMer的你帮她写一下. 输入

(转) 很牛的求职经历

工作刚刚落实,论文也刚完成,终于有时间对自己的求职历程及求职经验进行总结了.应同学要求,最近准备书写系列文章“我的求职历程及经验分享”,请大家关注,谢谢! (一):求职历程总结 2007 年1月10日,随着在三方协议上郑重签下自己的名字,我的求职历程终于划上了一个圆满的句号.在这三个月漫长而艰辛的过程中,我付出了很多,经历了很多, 也收获了很多.这一路走来,要感谢的人太多太多,尤其要感谢每一个在找工作过程中关心.帮助过我的人,我会一生铭记你们的恩情.现在,尘埃落定,到了该回 报的时候,我首先要回

第七章 恢复平静2

这也许就是为什么从我爸爸出事到到下葬始终都看不见王一民家人的原因吧.如果不是他们……,可是一切都晚了. 爸爸去世后,我请了半个月的假,老师象征性的问了几句后就同意了.妈妈阻拦了我几句后就不说了,我知道在这种情况下,妈妈也希望我能够陪着她,毕竟对她来说她的亲人已经不多了,一个80多岁的母亲已经在去年过世了,一个姐姐在很早以前就得了尿毒症死了.现在跟妈妈直接有血缘关系的只有我这一个13岁的女儿了.所以我不能离去,不能现在狠心丢下妈妈一个人独自守着这个家. 同我一起回来的6人中其他5个人都在星期天的下

类似QQ电脑空闲5分钟后自动更改状态的实现

今天复习了windows线程的调度,优先级等相关内容.以为将一个进程和它的线程都设为优先级最低,那么该进程将在电脑空闲的时候才会运行.我突然联系到有的程序比方说腾讯QQ或者屏保程序是不是将要调用的线程设为优先级最低,等到电脑空闲或空闲一段时间(具体时间程序当然可以调)才开始调用呢?然后我写程序验证了一下,发现任何时候该线程都会执行,哪怕是CPU到达了100%.为什么会这样呢?仔细看书得知,当今计算机运算速度非常快,哪怕鼠标键盘一直动个不停,计算机CPU还是会有很多空闲时间,这个空闲时间足以运行那

Android开发本地及网络Mp3音乐播放器(十一)使用Jsoup组件请求网络,并解析音乐数据

实现功能: 实现NetMusicListFragment(网络音乐界面) 实现net_music_list_layout.xml(网络音乐界面UI) 使用Jsoup组件请求网络,并解析音乐数据 截止到目前的源码下载: http://download.csdn.net/detail/iwanghang/9506985 Jsoup组件导入: AndroidStudio简单快速导入GitHub中的第三方组件 : http://blog.csdn.net/iwanghang/article/detail

[转]C++智能指针的创建

zero 坐在餐桌前,机械的重复“夹菜 -> 咀嚼 -> 吞咽”的动作序列,脸上用无形的大字写着:我心不在焉.在他的对面坐着 Solmyr ,慢条斯理的吃着他那份午餐,维持着他一贯很有修养的形象 ——— 或者按照 zero 这些熟悉他本质的人的说法:假象. “怎么了 zero ?胃口不好么?”,基本填饱肚子之后,Solmyr 觉得似乎应该关心一下他的学徒了. “呃,没什么,只是 …… Solmyr ,C++ 为什么不支持垃圾收集呢?(注:垃圾收集是一种机制,保证动态分配了的内存块会自动释放,J