}
【易错提示】 根据字符ASCII码的位计算;if判断语句中的逻辑表达式。
12. 【考点分析】 本题考查对字符数组中的字符计算。考查的知识点主要包括:字符串数组的访问,字符ASCII码的算术运算,if判断结构以及逻辑表达式。
【解题思路】 首先通读题目,得知此题属于字符计算问题;其次分析题干要求,本题要求实现ChA(void)函数的功能,分析后可以归纳出3个关键点:关键点1如何对字符数组的元素逐一访问;关键点2按照要求取每个位置的字符和其下一个字符相加,并将结果作为该位置上的新字符,需要注意的是,末尾位置的新字符是该位原字符和第1个原字符相加的结果;关键点3最后要将所得的结果逆序保存。
接着分析每一步的解决方法,对于关键点1通过字符串处理函数strlen获取字符串的长度,再通过获得的长度用下标法对字符数组的字符元素逐一访问;关键点2在遍历访问字符时,可以直接取下一个位置的字符进行运算,在进行计算之前需要首先保存第1个位置的字符,以作为计算最后位置新字符的条件;关键点3可以通过for循环对数组从首尾同时遍历的算法实现。
【参考答案】
void ChA(void)
{
int i,j,k; /*定义循环控制变量*/
int str; /*存储字符串的长度*/
char ch,temp; /*定义字符暂存变量*/
for(i=0;i<maxline;i++) /*以行为单位获取字符*/
{
str=strlen(xx[i]); /*求得当前行的字符串长度*/
ch=xx[i][0]; /*将第一个字符暂存入ch*/
for(j=0;j<str-1;j++)
/*将该字符的ASCII值赋值为下一个字符的ASCII值加1,得到新的字符*/
xx[i][j]+=xx[i][j+1];
xx[i][str-1]+=ch;
/*将最后一个字符的ASCII值与第一个字符的ASCII值相加,得到最后一个新的字符*/
for(j=0,k=str-1;j<str/2;j++,k--) /*将字符串逆转后仍按行重新存入字符串数组xx中*/
{
temp=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=temp;
}
}
}
【易错提示】 最后一个字符的计算,逆序存储算法的选择。