破译情报-NOIP2016提高组复赛模拟试题
【题目描述】
最近国安人员截获了一份 RB 国的秘密情报, 全文都是经过加密的,每个单 词都很长。破译人员想到先把单词化简一下,方法是把每个单词尽量取短些的前 缀,但所取的前缀不能是其他单词的前缀。 这个任务现在就交给你来完成。
解释:“字符串s1是s2的前缀”意思是把字符串s2的后面去掉某些字符,只保留与s1相同长度的子串,则s1就称为s2的前缀。如:“abc”是“abcaade”和“abc”的 前缀,但不是“abadc”的前缀。
数据范围 单词数 N, 1<=n<=50; 每个单词长度不超过 50;并且都是由小写字母构成。 保证所给单词没有一个单词是另一个单词的前缀。
【输入文件 addreviate.in】
第一行一个整数 N,表示单词的个数。 下面有 N 行,每行一个单词。
【输出文件 addreviate.out】
共 N 行,每行一个单词,是对应上面 N 个单词化简后的单词。
【样例输入】
样例测试点#1:
3
abc
efg
ijh
样例测试点#2:
3
aac
aad
aae
【样例输出】
样例测试点#1:
a
e
i
样例测试点#2:
aac
aad
aae
思路:这题算是送分题中的高难度题了,对于各位高手来说不是什么问题,我说这题是为了提一下一个库函数,这个库函数是我们一般不经常用的,废话不多说,我先从头讲起吧
这题要求我们保留n个字符串的前缀,使得这些前缀和其他前缀不相同,缩小存储空间,看起来很简单,其实还是有点复杂滴
例如题目中给的样例:
可以先把第一个字符按照图中红线分段,提取第一行第一个字符,来和下面的每一个字符串进行对比
,如果这个段并不在下面任何一个字符串中是前缀,就可以在后面加上个'\0'表示截取这一段
之后对每一行都采取这样的措施,就可以实现保留前缀
代码如下:
#include <stdio.h>
#include <string.h>
int main()
{
//freopen("addreviate.in","r",stdin);
//freopen("addreviate.out","w",stdout);
char a[][],temp;
int n;
int i,j,k;
int flag,len;
scanf("%d",&n);
for(i=;i<n;i++)
{
scanf("%s",a[i]);
}
for(i=;i<n;i++)
{
len=strlen(a[i]);//测一下a[i]的长度
for(k=;k<len;k++)//扫描整个子串
{
temp=a[i][k];//记录一下当前字符
a[i][k]='\0';//当前标记为空
for(j=;j<n;j++)
{
if(i!=j&&(strstr(a[j],a[i])-a[j])==)//如果不是同一行,并且这个子串与这个字符串的前面一部分吻合,就可以停止了
{
break;//停止!!
}
}
if(j>=n)//这个空的位置前面一段保证前缀不重复,就可以标记为空了
{
a[i][k]='\0';
break;
}
else//否则还要还原回去,继续寻找下一位
{
a[i][k]=temp;
}
}
}
for(i=;i<n;i++)
{
printf("%s\n",a[i]);
}
return ;
}
破译情报-NOIP2016提高组复赛模拟试题的更多相关文章
- 冲刺NOIP2015提高组复赛模拟试题(五)2.道路修建
2.道路修建 描述 Description liouzhou_101最悲痛的回忆就是NOI2011的道路修建,当时开了系统堆栈,结果无限RE… 出于某种报复心理,就把那题神奇了一下: 在 Z星球上有N ...
- CCF-NOIP-2018 提高组(复赛) 模拟试题(四)
T1 贪吃蛇 [问题描述] 贪吃蛇是一个好玩的游戏.在本题中,你需要对这个游戏进行模拟. 这个游戏在一个 \(n\) 行 \(m\) 列的二维棋盘上进行. 我们用 \((x, y)\) 来表示第 \( ...
- CCF-NOIP-2018 提高组(复赛) 模拟试题(九)(2018 CSYZ长沙一中)
T1 Circle [问题描述] 小 w 的男朋友送给小 w 一个 n 个点 m 条边的图,并且刁难小 w 要她找出点数最少的正环. 小 w 不会做,于是向你求助. [输入格式] 第一行两个整数\(n ...
- CCF-NOIP-2018 提高组(复赛) 模拟试题(七)
T1 Adjoin [问题描述] 定义一种合法的\(0-1\)串:串中任何一个数字都与\(1\)相邻.例如长度为$ 3 的 0-1 $串中,\(101\)是非法的,因为两边的\(1\)没有相邻的\(1 ...
- CCF-NOIP-2018 提高组(复赛) 模拟试题(一)
T1 帽子戏法 问题描述 小 Y 有一个\(n*n*n\)的"帽子立方体" ,即一个\(n\)层的立方体,每层的帽子都 可以排成\(n*n\)的矩阵. "帽子立方体&qu ...
- 冲刺NOIP2015提高组复赛模拟试题(五) 3.破坏基地
3.破坏基地 描述 Description 在Z国和W国之间一直战火不断. 好不容易,W国的间谍把完整的Z国的军事基地的地图到手了. 于是W国决定再次出击,一举击破Z国的防线. W国认真研究了Z国的地 ...
- 冲刺NOIP2015提高组复赛模拟试题(五)1.数学作业
1. 数学作业 [问题描述] 路人丙的数学老师非常乏力,他喜欢出一些非常乏力的数学题来为难乏力的学生们.这次数学老师布置了一堆的数学题作为作业,而且这些数学题有个共同的特点是都求C(N,M)中不同质因 ...
- CCF-NOIP-2018 提高组(复赛) 模拟试题(五)
T1 相遇 [问题描述] 在一场奇怪的梦里,小 Y 来到了一个神奇的国度.这个国度可以用一根数轴表示,小 Y 在 N 处,而小 Y 想吃的美食在 K 处.小 Y 有两种方式移动, 一种叫做步行, 一种 ...
- CCF-NOIP-2018 提高组(复赛) 模拟试题(三)
T1 取球游戏 问题描述 现有\(N\)个小球,依次编号为\(1\)到\(N\),这些小球除了编号以外没有任何区别.从这\(N\)个小球中取出\(M\)个,请问有多少种取球方案使得在取出的\(M\)个 ...
随机推荐
- 取得ASKII码值和汉语拼音
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAXMAAACmCAIAAACnXPjtAAAgAElEQVR4nO2de3wb1YHv56+7e/fe/e ...
- Forms Authentication in ASP.NET MVC 4
原文:Forms Authentication in ASP.NET MVC 4 Contents: Introduction Implement a custom membership provid ...
- [转]在 Mac OS X上编译 libimobiledevice 的方法
link: http://blog.boceto.fr/2012/05/05/libimobiledevice-for-macosx/ The objective of the day: Compil ...
- defer 与 async
defer HTML4.01定义的 只适用于外部脚本(IE4~7会支持内嵌脚本的defer属性) 告诉浏览器立即下载,延迟执行,脚本会延迟到整个页面全部解析完毕之后才运行 HTML5规范要求脚本按照他 ...
- C++内存中的封装、继承、多态(上)
C++内存中的封装.继承.多态(上) 继我的上一篇文章:浅谈学习C++时用到的[封装继承多态]三个概念 此篇我们从C++对象内存布局和构造过程来具体分析C++中的封装.继承.多态. 一.封装模型的内存 ...
- myeclipse 配置 resin-pro-4.0.34
热部署: 在 resin.xml 文件下 增加 <host id="" root-directory="."> <!-- webapps ca ...
- T-SQL编程的基本语法和思想
通过一个很实用的例子让你学会T-SQL编程的基本语法和思想 例子需求:把Execl中的三级分类(列别的三级联动)数据导入到数据库中. Excel表中数据的显示格式: 图1 数据库中表的显示格式: ...
- 分享个自己做的CSDN刷下载积分软件
对于评论里有人反映说,运行完后自动关机了,我要在这解释下,不好意思了亲们,由于昨晚开这个通宵刷积分,就加了个功能,刷完所有可刷积分后自动关机省点电.今天发布的时候忘记取消了.这里给大家带来不便请大家包 ...
- 使用Pechkin将HTML网页转换为PDF
Pechkin开源组件使用wkhtmlbox,可以解析CSS样式,将网页转换为PDF文件, 支持URL,或者HTML字符串 1, 从NuGet程序管理器中获得Pechkin GlobalConfig ...
- aix上使用裸设备安装oracle10g数据库
一.检查系统信息 [root@aix222 /]# oslevel -r 5300-08 [root@aix222 /]# prtconf | grep -i mem Memory Size: 190 ...