NOIP2011复赛编程题解析:数字反转与单词统计

需积分: 9 1 下载量 13 浏览量 更新于2024-09-15 收藏 62KB DOC 举报
"NOIP2011复赛普及组的试题包含了两个编程题目,分别是数字反转和统计单词数。" 这两个题目都是编程竞赛中常见的基础算法问题,适合初学者练习。 1. **数字反转** - **问题描述**:这个题目要求编写程序将输入的整数反转,反转后的新数应遵循整数的常规形式,即非零数的最高位不能为0。 - **输入**:输入一个整数N。 - **输出**:输出反转后的新数。 - **示例**:输入123,输出321;输入-380,输出-83。 - **解决方案**:可以使用字符串操作来实现,首先将整数转换为字符串,然后从后向前读取每一位,构建新的字符串,最后再将字符串转换回整数。例如,Pascal代码示例中使用了`str(abs(n),s)`将整数转换为字符串,通过数组`v`存储反转后的字符,再用`val(v,l)`将字符串转换回整数。 2. **统计单词数** - **问题描述**:此题目的任务是统计给定单词在一篇文章中出现的次数和首次出现的位置,匹配时不区分大小写,但要求完全匹配,即单词必须与文章中的独立单词完全一致。 - **输入**:第一行是给定的单词,第二行是包含字母和空格的文章文本。 - **输出**:如果找到给定单词,输出出现次数和首次出现的位置;若未找到,输出-1。 - **示例**:输入"To be or not to be is a question",输出"2 0",表示单词"To"在文章中出现两次,首次出现在位置0。 - **解决方案**:遍历文章,对每个单词进行大小写不敏感的比较,统计匹配次数并记录首次出现的位置。可以使用字符串分割函数将文章分解成单词,然后逐个与目标单词进行比较。 对于参加NOIP这样的编程竞赛的学生来说,掌握这类基本的算法和数据结构是至关重要的,它们是解决问题的基础。通过解决这些问题,学生可以提升逻辑思维、字符串处理和文本分析的能力。同时,这也是计算机科学教育的重要组成部分,有助于培养未来程序员的基础技能。