比较字符串的大小

//功能:比较字符串的大小
//如果str1>str2返回1
//如果str1=str2返回0
//如果str1<str2返回-1
char zstrncmp(unsigned char *str1,unsigned char *str2,byte num)
{
   while(num!=0)
   {
      if((*str1)==(*str2))
      {
         str1 ++;
         str2 ++;
         num --;
      }
      else if((*str1)>(*str2))
         return(1);
      else
         return(-1);
   }
   return(0);
}

 

 

       如果单纯比较长度,直接调用类似于strlen()之类的函数就可以,加以比较即可.

       如果比较字符串的大小,则比较的是字符的ASCII编码的大小.搜索一下ASCII码表就可以得知每一个ASCII字符的大小. 

       在比较时,设置一个计数器,从零开始,一直循环到最短的那个字符结束,一位一位进行比较,

           1.如果 字符串1的第n位的ASCII码值 等于 字符串2的第n位的ASCII码值 则 继续比较下一位

                若if( zstrncmp(unsigned char *str1,unsigned char *str2,byte num)==0 )   //表示str1=str2

           2.如果 字符串1的第n位的ASCII码值 大于 字符串2的第n位的ASCII码值 则 输出结果:1,表示字符串1 > 字符串2;

           3.如果 字符串1的第n位的ASCII码值 小于 字符串2的第n位的ASCII码值 则 输出结果:-1 表示字符串1 < 字符串2;

           4.如果 每一位的ASCII码值都相等,而且长度相同, 则 输出结果:0 表示字符串1 == 字符串2;

           5.如果 字符串1是字符串2的前m位,例如 abcd 与abcdef 比较, 则 字符串1<字符串2. 原因是,到第5位时,字符串1的ASCII值是0,而字符串2的ASCII值为'e',即十进制的101,

               当然是字符串2大了.

 

  举例:

      如 cds和lesoqd比较。 从第一位开始,'c'和'l'比较,当然是'c' < 'l'了,所以,"cds" < "lesoqd"   ,return 1.

          常用的几位ascii的顺序从小到大为: 0..9, A..Z, a..z.

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值