【答案】
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] *13%256;
if(ch<=32 || ch%2==0)
/*如果计算后的值小于等于32或其ASCII值是偶数*/
continue; /*则该字符不变,去取下一个字符*/
else
xx[i][j]=ch*13%256; /*否则将新字符替代原字符*/
}
}
}
【解析】本题要对二维数组中的字符元素按行来处理。
首先用strlen()函数得到当前行所包含的字符个数。
然后再利用一个循环来依次访问该行中的所有字符。对于每一个字符,先按照题目中的函数替代关系"f(p)=p*11 mod 256"计算出相应的fp值,再用一条if语句判断该值是否符合本题给定的条件:计算后的值小于等于32或其ASCII值是偶数。如果符合条件,则该字符不变,否则用f(p)所对应的字符对其进行替代。