结论
strcmp函数是通过比较两个字符串首字母的ascll码值来排序。ascll码值大的,自然就大一点。如果首字母相同,就比较后一位,以此类推.......
证明
函数定义
int strcmp(const char *str1, const char *str2);
如果arr1>arr2函数返回1;
如果arr1=arr2函数返回0;
如果arr1<arr2函数返回-1;
arr1数组内放的是"ba",arr2数组内放的是"ab",我们得到的结果是1,也就是arr1>arr2
我们再将arr2延长,得到的结果仍然是1。arr1>arr2,这是不是就说明,strcmp函数并不是按照字符串的长短来进行比较大小的。
前面我们已经知道,和字符串的长短无关。那我们再将arr2的首字母改成c,c的ascll码值>b的ascll码值,函数值返回的内容是-1,这说明arr2>arr1。
我们再在连个字符串前面都加入一个相同的字符d,结果不变,仍然是arr1<arr2
课件首字母ascll相同时,就会比较后一位,以此类推
如果字符串是汉字的话
“张三”的拼音zhang,首字母是z
“李四”的拼音li,首字母是l
很明显z的ascll码值是大于l的,那我们大致可以推出来应该是张三>李四
结果是1,和我们推理的一致;
至于后面的“张大炮”和“张大大”,前两个汉字的拼音是一样的,所以就要比较第三个字的拼音,我
们发现,“炮”的首字母是p,“大”的首字母是d,p>d,根据我们的理论,应该是“张大炮”>“张大大”
经过试验,我们发现结果是1,和我们的推理一致。
所以可以得出结论
strcmp函数是通过比较两个字符串首字母的ascll码值来排序。ascll码值大的,自然就大一点。如果首字母相同,就比较后一位,以此类推.......