程序以一个数组记录大写字母的个数
int cipher[26];
注意是只有26个字母
如果只用
cipher[input[i]]++;
由于大写字母ascii码由65('A')开始,所以造成
cipher['A'] (等价于cipher[65]) 数组越界
一种方法是开大cipher数组使之不越界,但是这样造成了空间的浪费(0~64个毫无用处)
于是另一种作法是把'A'往前移65,成为0,把'B'往前移65,成为1……此类推
这个65就是字母'A'的ascii码,把任意大写字母往前移65位就是 input[i]-65
(等价于input[i]-'A')
所以在处理的时候出现cipher[ input[i]-‘A' ]++;