codeup墓地 习题6-12

#include
int main(){
char a[50];
int i;
gets(a);
for(i=0;i<50;i++){
if(65<=a[i]&&a[i]<=90){ //如果输入的字符在ascii表中在65到90之间
a[i]=155-a[i];
}
if(48<=a[i]&&a[i]<=57){
a[i]=a[i];
}
if(97<=a[i]&&a[i]<=122){
a[i]=219-a[i];
}
}
puts(a);
}

本体关键在于对ascii表中0-9,a-z,A-Z位置的认知;
0-9对应48-57,a-z对应65-90,A-Z对应97-122.
在字符数组中直接输入数或者字符均代表的是ascii值例如65代表a.也就是说电脑只认ascii值,经过对比ascii值来进行输出。输出的是ascii值对应的符号而不是ascii值。我在这里直接用的数字与字符数组的比较电脑默认为ascii值的比较。举例a的ascii值为65,如果a<=65就转变为65<=65;条件符合,进入转变90-(65-65);即转变为ascii值为90的符号;大致如此。

还有可以用’a’,‘A’,‘0’,来表示ascii值,即将上面代码中65替换为‘a’也行。同时a[i]的替换计算也要跟着发生改变具体代码如下:
#include
int main(){
    char a[50];
    int i;
    gets(a);
    for(i=0;i<50;i++){
        if(‘a’<=a[i]&&a[i]<=‘z’){
            a[i]=‘a’+‘z’-a[i];
        }
        if(‘0’<=a[i]&&a[i]<=‘9’){
            a[i]=a[i];
        }
        if(‘A’<=a[i]&&a[i]<=‘Z’){
            a[i]=‘A’+‘Z’-a[i];
        }
    }
    puts(a);
}

你可能感兴趣的:(codeup墓地 习题6-12)