第36套试题答案及详解
【审题分析】分析题目可知,本题只要实现encryptChar()函数的功能即可。encryptChar()要实现的功能是:按给定的替代关系对数组str中的所有字符进行替代后,仍存入数组str的对应位置上,因此解答本题的关键在于如何把给定的替代关系转换为C语言表达式。
【解题思路】在for循环语句中对宁符串数组str中的每个字符用逻辑表达式(*pf*11%256>='0'&&*pf*11%256<='9')||*pf*11%256<=32进行逻辑判断,如果其值为1,则该字符不变,台则按照给定的替代关系f(p)=p*1 lmod256求出其要替代的字符的ASCII值,然后对该字符进行替代。
【参考答案】
14 }
15 }
【易错分析】while循环语句的逻辑判断表达式为*pf!=0,因为在字符串数组中存入的最后一个字符是null字符,所以用表达式*pf!=0来判断是否进行到字符串的末尾。计算后坟p)值小于等于32或f(p)对应的字符是数字0至9,这句话对应的表达式为(*pf*11%256>='0'&&*pf*11%256<='9')||*pf*11%256<=32。
【考点链接】字符ASCII值的相互替换。
责任编辑:小草