在C语言中,有一个strcmp函数,其功能是比较两个字符串s1和s2。请编写一个你自己的字符串比较函数my_strcmp,来实现strcmp函数的类似功能。如果s1=s2,则返回0;否则返回s1 与s2 第一个不同字符的差值(如果s1<s2,该差值是一个负数;如果s1>s2,该差值是一个正数)。编写测试程序,输入两个长度小于1000的字符串(可能包含有空格,且长度不一定相等),然后调用my_strcmp函数来进行比较,并输出返回结果。
输入:
aBcDefgf
aacdef
输出:
-31
(@_@)简单题,但是我写了好多次才AC,老是忘记边际条件
import java.util.Scanner;
/**
* @author sjn
* @date 2022-2-15
*/
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s1 = sc.nextLine(), s2 = sc.nextLine();
System.out.println(my_strcmp(s1, s2));
}
public static int my_strcmp(String s1, String s2) {
if (s1.equals(s2))
return 0;
int len = Math.min(s1.length(), s2.length());
for (int i = 0; i < len; i++) {
if (s1.charAt(i) != s2.charAt(i)){
return s1.charAt(i) - s2.charAt(i);
}
}
return len == s1.length() ? -s2.charAt(len) : s1.charAt(len);
}
}