北邮计算机学院2008研究生复试上机模拟试题解析

需积分: 9 12 下载量 148 浏览量 更新于2024-09-27 收藏 28KB DOC 举报
"2008年北京邮电大学计算机学院研究生入学考试复试的上机测试模拟试题,包括人数统计和统计字母两道题目。" 本文将详细解析这两道编程题目及其解题思路。 第一题:人数统计 题目要求编写程序统计每组复试同学中的男生和女生总数。输入数据包括测试用例的数量`t`,每组复试人数`n`,以及每个学生的性别(0代表男生,1代表女生)。程序需输出每组的男生和女生数量。 解题思路: 1. 首先读入测试用例数量`t`。 2. 使用动态内存分配创建一个大小为`maxsize`的数组来存储每组的数据。 3. 对于每一组,读入人数`n`和性别数组,然后遍历数组,统计男生(值为0)和女生(值为1)的数量。 4. 输出每组的男生和女生数量,然后清零计数器,准备处理下一组数据。 给出的代码实现了上述思路,使用了两个全局变量`male`和`female`来分别记录男生和女生的数量,`array_addr`是一个指针数组,用于存储每组的性别数据。在每次循环中,通过指针访问数组元素,判断性别并更新计数器。 第二题:统计字母 这道题目没有提供完整的信息,但根据常规的编程竞赛题目,可能是要求统计一段文本或字符串中字母的出现次数。通常,输入可能是一段包含各种字符的字符串,输出是各个字母(可能区分大小写)的计数。 解题思路: 1. 读入输入字符串。 2. 初始化一个足够大的数组(如26个元素,如果区分大小写则52个元素)来记录每个字母(或每个大小写字母)的出现次数。 3. 遍历字符串,对每个字符进行判断,如果它是字母,则增加对应字母计数器。 4. 输出每个字母的计数。 虽然题目不完整,但基本的解题策略如上所述。实际编程时,需要注意字符类型判断(如使用`isalpha()`函数),以及是否区分大小写。 这两道题目均属于基础的算法题目,旨在考察考生的基本编程能力和问题解决能力。通过这样的练习,考生可以提高处理数组、动态内存分配、循环、条件判断等编程技能,以及数据统计和分析的能力。