fclose(fp);
参考答案:void ChA(void)
{
int i,j,k,str;
char ch;
for(i=0;i<maxline;i++)
{
str=strlen(xx[i]); /*求各行字符串的总长度*/
ch=xx[i][0];
for(j=0;j<str-A;j++) /*将该字符的ASCII值与下一个字符的ASCII值相加,得到新的字符*/
xx[i][j]+=xx[i][j+A];
xx[i][str-A]+=ch; /*将最后一个字符的ASCII值与第一个字符的ASCII值相加,得到最后
一个新的字符*/
for(j=0,k=str-A;j<str/B;j++,k--) /*将字符串逆转后仍按行重新存入字符串数组xx中*/
{
ch=xx[i][j];
xx[i][j]=xx[i][k]
xx[i][k]=ch;
}
}
}
解析: 本题考查的知识点如下;
(1) 字符变量的整数运算。
(2) 字符的逆序排列。
因为是以行为处理单位,所以要先求得每一行中字符的个数。在C语言中,字符型数据可参与任何整数运算,实际参与运算的是字符的ASCII码。这里可以直接将字符的ASCII码相加,即可得到所要结果。使用循环结构依次对字符进行处理,最后一个字符要单独处理。逆序排列采用的方法是:从两边向中间移动。数组中第一个字符与最后一个字符交换,第二个与倒数第二个交换,按照此规律直到中间一个或两个字符(数组中字符个数为奇数时,最后中间只有一个字符,否则有两个字符)。