noip普及组复赛模拟试题26(答案).doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
noip普及组复赛模拟试题26(答案)

1.数字反转(reverse.cpp/c/pas)【问题描述】给定一个整数,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例2)。【输入】输入文件名为 reverse.in。 输入共 1 行,一个整数N。 【输出】输出文件名为 reverse.out。 输出共 1 行,一个整数,表示反转后的新数。 【输入输出样例 1】reverse.in reverse.out 123 321 【输入输出样例 2】Reverse.in reverse.out -380 -83 【数据范围】-1,000,000,000 ≤ N≤ 1,000,000,000。 var ? s3,s1,s2:string; ? n,i:integer; begin ? assign(input,reverse.in);reset(input); ? assign(output,reverse.out);rewrite(output); ? read(s1); ? n:=length(s1); ? if s1[1]=- then ? begin ?牋 s2:=-; 牋?for i:=1 to n-1 do 牋牋?s1[i]:=s1[i+1]; 牋?delete(s1,n,1); ?end; ?n:=length(s1); ?for i:=1 to n do ?s3:=s3+s1[n-i+1]; ?i:=1; ?while(s3[i]=0)and(length(s3)1) do delete(s3,1,1); ?write(s2+s3); ?close(input);close(output); end. 2.统计单词数(stat.cpp/c/pas)【问题描述】一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数。 现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给定的文章 中出现的次数和第一次出现的位置。注意:匹配单词时,不区分大小写,但要求完全匹配, 即给定单词必须与文章中的某一独立单词在不区分大小写的情况下完全相同(参见样例1), 如果给定单词仅是文章中某一单词的一部分则不算匹配(参见样例2)。 【输入】输入文件名为 stat.in,2 行。 第 1 行为一个字符串,其中只含字母,表示给定单词; 第 2 行为一个字符串,其中只可能包含字母和空格,表示给定的文章。 【输出】输出文件名为 stat.out。 只有一行,如果在文章中找到给定单词则输出两个整数,两个整数之间用一个空格隔开, 分别是单词在文章中出现的次数和第一次出现的位置(即在文章中第一次出现时,单词首字 母在文章中的位置,位置从0 开始);如果单词在文章中没有出现,则直接输出一个整数-1。 【输入输出样例 1】stat.in stat.out To to be or not to be is a question 2 0 【输入输出样例 1 说明】输出结果表示给定的单词 To 在文章中出现两次,第一次出现的位置为0。 【输入输出样例 2】stat.in stat.out to Did the Ottoman Empire lose its power at that time -1 【输入输出样例 2 说明】表示给定的单词 to 在文章中没有出现,输出整数-1。 【数据范围】1 ≤ 单词长度≤ 10。1 ≤ 文章长度≤ 1,000,000 第二题有个陷阱,如果纯粹用字符串的7个操作命令,由于字串很长,后面几个点肯定超时。第二行的长串可以用字符一个个读。遇到空格跟上一行的串进行比较。这样能保证在规定时间内不超时。 var? s1,s2:string;? ch:char; ? s,first,n,i,ans:longint; begin? assign(input,stat.in);reset(input); ? assign(output,stat.out);rewrite(output); ? readln(s1);? s1:=upcase(s1); ? first:=-1;?n:=length(s1); ?while not eoln do ?begin 牋?s2:=;牋?repeat 牋牋?inc(s);牋牋?read(ch);牋牋?ch:=upcase(ch); 牋牋?if ch then s2:=s2+ch; 牋?until (ch= )or eoln; 牋?if s2=s1 then 牋牋?if first=-1 then 牋牋?begin 牋?

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档