【答案】
void encryChar()
{
int i,j; /*定义循环控制变量*/
int str; /*存储字符串的长度*/
char ch; /*存储当前取得的字符*/
for(i=0;i<maxline;i++) /*以行为单位获取字符*/
{
str=strlen(xx[i]); /*求得当前行的字符串长度*/
for(j=0;j<str;j++) /*依次取每行的所有字符*/
{
ch=xx[i][j] *11%256;
if((xx[i][j]>= 'A'&& xx[i][j]<='Z')|| ch<=32)
/*如果原字符是大写字母或计算后的值小于等于32*/
continue; /*则此字符不变,取下一个字符*/
else
xx[i][j]=ch; /*如果不满足条件,则用新字符替代原字符*/
}
}
}
【解析】本题要对二维数组中的字符元素按行处理。
首先用strlen()函数得到当前行所包含的字符个数。
然后再利用for循环来依次访问该行中的所有字符。对于每一个字符,先按照题目中的函数替代关系"f(p)=p*11 mod 256"计算出相应的fp值,再用一条if语句判断该值是否符合本题给定的条件:"原字符是大写字母或计算后的值小于等于32"。如果符合条件,则该字符不变,否则用f(p)所对应的字符对其进行替代。