字符串比较函数实现,超简单的面试题,回过头来发现原来我的c多么的薄弱
生活随笔
收集整理的這篇文章主要介紹了
字符串比较函数实现,超简单的面试题,回过头来发现原来我的c多么的薄弱
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
今天某個公司面試,盡管報了個測試類的,但是面試依舊不給力,先是寫個字符串比較函數,只判斷相等和不相等的情況,當時大概這么寫的:
#include<stdio.h>bool strCompare(char *str1,char *str2){
char *s1=str1,*s2=str2;
printf("%c and %c\n",*s1,*s2);
while(s1&&s2){
if(*s1!=*s2){
printf("%c and %c\n",*s1,*s2);//調試專用
printf("test\n");
return false;
}
s1++;
s2++;
}
if(!s1&&!s2)return true;
return false;
}
int main(){
char st1[]="baibai";
char st2[]="baibai";
char st3[]="daibai";
if(strCompare(st1,st2))printf("success\n");
else printf("fail\n%c\n",*st1);
if(strCompare(st1,st3))printf("fail\n");
else printf("success\n");
}
shit,回來測試一下,發現第一個用例錯了,截圖如下
然后一直覺得是不是cfree問題,后來去vs2008那邊逐行調試了一下,才知道自己弱爆了:
bool strCompare(char *str1,char *str2){char *s1=str1,*s2=str2;
printf("%c and %c\n",*s1,*s2);
while(*s1&&*s2){
if(*s1!=*s2){
printf("%c and %c\n",*s1,*s2);
printf("test\n");
return false;
}
s1++;
s2++;
}
if(!*s1&&!*s2)return true;
return false;
}
看到木有,丫的,居然是因為那個while判斷出問題了,太久沒用c還是說根本沒把c當一回事。
那時思考:
要是是while(s1&&s2)的話,遍歷到最后(字符串結尾)還會一直遍歷。實際上就是遍歷到真正沒有地址的時候才停下來(不知道這么說對不對,求指正),這個時候s1跟s2存的數值是神馬,就不得而知了。唉,發現了錯誤之后,還是感覺挺爽的,但是為自己如此弱的水平,實在感慨……神馬招聘都不敢報c++了
轉載于:https://www.cnblogs.com/dont27/archive/2011/10/12/2208037.html
總結
以上是生活随笔為你收集整理的字符串比较函数实现,超简单的面试题,回过头来发现原来我的c多么的薄弱的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: windows下的_mkdir函数
- 下一篇: 89C52控制1602A液晶的计时器