如果现在这样规定英语单词,从A~M分别为1~26,空格为零,按如下规则计数,输入大写的英文字母,要求所代表的的数。
例:ACM=1*1+2*3+3*13
A C M=1*1+2*1+3*3+4*0+5*13
#include<string.h>
int main()
{ char str[80];
int sum=0,i;
while((gets(str))!='\0')
{for(i=0;str[i]!='\0';i++)
{
if(str[i]==' ')
str[i]=str[i]-' ';
else
str[i]=str[i]-'@';
}
sum=0;
for(i=0;str[i]!='\0';i++)
{
sum=sum+(i+1)*str[i];
}
printf("%d\n",sum);
}
return 0;
}
这道题目上手的最大的问题不在于字符的变换,而在于条件的控制以及满足多组数据的输入和输出。
这个时候用while是个很不错的选择,ACM的训练题型总有很多的后台测试数据。