有這樣一個題目 字符串(實現(xiàn)字符串比較函數(shù)) 輸入兩個字符串,然后不區(qū)分大小寫進行比較,輸出比較結(jié)果; 要求實現(xiàn)一個字符串比較函數(shù),不區(qū)分大小寫進行比較,如果第一個字符串大輸出1,相等輸出0,小于輸出-1。 比如: 輸入 HELLO hello 輸出為0 輸入 hello hello 輸出為0 輸入 Hello hEllo 輸出為0 輸入 hello gello 輸出為1 輸入 hello jello 輸出為-1
在看到這個題目的時候,我們通常的想法是分情況討論,如果兩個字符串的長度一樣,那么我們按照順序比較即可不用擔心越界的問題,但是這里會出現(xiàn)冗余代碼的問題
static int MyCompare2(string str, string str2){ //字符串str的長度大于str2的長度 if (str.Length > str2.Length) { //取比較短的字符串作為比較對象 不用擔心越界的問題 for (int i = 0; i < str2.Length; i++) { //下面的比較代碼就是和else if中的代碼就構(gòu)成了冗余的代碼 if (str[i] > str2[i]) { return 1; } else if (str[i] < str2[i]) { return -1; } } return 1; } //字符串str的長度小于str2的長度 else if (str.Length < str2.Length) { //取比較短的字符串作為比較對象 不用擔心越界的問題 for (int i = 0; i < str.Length; i++) { if (str[i] > str2[i]) { return 1; } else if (str[i] < str2[i]) { return -1; } } return -1; } //剩下的就是相等的情況了,直接返回0 return 0;}我們要把冗余代碼去掉 改進方法后的代碼如下
static int MyCompare2(string str, string str2){ //我們?nèi)〉谝粋€字符串為比較對象 假如str的字符串比較短,那么在i++過后i編程str.Length的時候?qū)鲅h(huán) for (int i = 0; i < str.Length; i++) { //如果str的長度比較短,那么在i++過后i編程str2.Length的時候?qū)?zhí)行break跳出循環(huán) if (i > str2.Length-1) { break; } if (str[i] > str2[i]) { return 1; } else if (str[i] < str2[i]) { return -1; } } //這時候我們來判斷字符串的長短就可以得到 //首先我們來看返回值的特征 -1 0 1 絕對值是相對0對稱的,那么我們可以考慮結(jié)合絕對值思考問題 //因為去取-1還是取1是取決于str.Length - str2.Length還是str2.Length - str1.Length,如果str.Length > str2.Length那么(str.Length - str2.Length) / Math.Abs(Math.Abs(str.Length - str2.Length))就是1 ;如果str.Length < str2.Length那么(str.Length - str2.Length) / Math.Abs(Math.Abs(str.Length - str2.Length))就是-1;否則就是0; return Math.Abs(str.Length - str2.Length) == 0 ? 0 : (str.Length - str2.Length) / Math.Abs(Math.Abs(str.Length - str2.Length));}新聞熱點
疑難解答