关于ASCLL

基础不扎实!!!

1.得到一个字符的ascll 码值:

char ch;
cin>>ch;
cout<<(int)ch;

2.比较字符串的ascll

思路:

1.从第一个字符开始比较,如果a字符串的第n个字符的ascll码值>b字符串的第n个字符的ascll码值,则a>b;反之a<b,若相等继续比较下一位;

2.若a和b长度相等且每个字符都相同,则a=b;

3.若a是b的前一部分,例如abcd和abcdef,则a<b;

然后,我觉得思路没毛病,,,程序一如既往地不对

#include<stdio.h>
#include<string.h>
int min(int a,int b){
    return a>b?b:a;
}
char str1[100],str2[100];
int main(void){
    int len1,len2,i,flag=0;
    scanf("%s",str1);
    scanf("%s",str2);
    len1=strlen(str1);
    len2=strlen(str2);
    for(i=0;i<min(len1,len2);){
            if((int)str1[i]>(int)str2[i]){
                flag=1;
                break;         //判断出来以后要跳出循环
            }
            else if((int)str1[i]<(int)str2[i]){
                flag=-1;
                break;
                }
            else if((int)str1[i]==(int)str2[i])
                i++;
        }
    //注意此处有三种情况,len1<len2,len1>len2,还有相等,不过相等可以不写;
    if((i==min(len1,len2))&&(len1<len2))      //i=min(,),不是min-1
        flag=-1;
    else if((i==min(len1,len2))&&(len1>len2))
        flag=1;

    if(flag==1)
        printf("str1>str2");
    else if(flag==-1)
        printf("str1<str2");
    else
        printf("str1=sre2");
    return 0;
}


猜你喜欢

转载自blog.csdn.net/han_hhh/article/details/80572298
今日推荐