黑马程序员技术交流社区
标题:
【上海校区】兄弟字符、版本号比较
[打印本页]
作者:
梦缠绕的时候
时间:
2018-11-26 09:35
标题:
【上海校区】兄弟字符、版本号比较
兄弟字符:只通过了71.4%,难道漏了什么情况?知道的还望讨论补充。
问题:类似“abc”,"acb","cba"这样的调换两个字符顺序的字符串称为兄弟字符串,现输入两个字符串,判断是否为兄弟字符串,是则输出1,否则输出0。
输入输出示例:
示例一:
ab ba
1
示例二:
aa aa
1
示例三:
ab ab
0
分析:字符串处理问题。1)先比较两个字符串长度是否相同,长度是否为1,不同或长度为1的返回0。2)是否能找到不同的字母,找不到且长度不为1的返回1,找到了但数目不为2返回0(为0的是特殊情况),找到了且数目等于2则进入下一个判断。3)如果数目为0,若字符串类似“aa”这样由一个字母组成的,则返回1。4)找到2个不同的字母后,交换两个字母的位置,看两个字符串是否相同,相同返回1。
代码:
import java.util.ArrayList;
public class Test2 {
public static void main(String[] args) {
// TODO Auto-generated method stub
String strA = "aa";
String strB = "aa";
int lenA = strA.length();
int lenB = strB.length();
if(lenA != lenB || lenA == 1){
System.out.println(0);
return;
}
int count = 0;//用来计不同字母的数量
char start = strA.charAt(0);//A的首个字母,用于比较A是否为全由同一个字母组成
int count2 = 0;//记录A中与A首字母相同的字母个数,用于比较A是否为全由同一个字母组成
ArrayList<Integer> list = new ArrayList<>();//用来保存不同字母的位置
for(int i=0; i<lenA; i++){
if(strA.charAt(i) != strB.charAt(i)){
count++;
list.add(i);
}
if(strA.charAt(i) == start){
count2++;
}
}
if(count == 0 && count2 == lenA){
System.out.println(1);
return;
}else if(count != 2){
System.out.println(0);
return;
}
char b1 = strB.charAt(list.get(0));
char b2 = strB.charAt(list.get(1));
String strC = "";
for(int i=0; i<lenA; i++){
if(i == list.get(0)){
strC += b2;
}else if(i == list.get(1)){
strC += b1;
}else{
strC += strB.charAt(i);
}
}
if(strA.equals(strC)){
System.out.println(1);
}else{
System.out.println(0);
}
}
}
版本号比较:已AC
问题:比较两个字符串所代表的版本号的大小,若A比B大,则输出1,相等输出0,小则输出-1。
输入输出示例:
示例一:
"7.2.3" "7.2.4"
1
示例二:
"7.0" "7.0.1"
-1
示例三:
"7.0" "7"
0
分析:字符串处理问题。和上题一样,要考虑全面才能全部通过。1.先遍历AB中长度相同的部分,A大于B,输出1,A小于B输出-1,A等于B,记录个数;2)若A等于B的个数与A的长度、B的长度都相等,则同输出0;3)若A的长度大于B,则A中剩下的只要有不为0的数,则输出1,否则输出0;4)若B的长度大于A,则B中剩下的只要有不为0的数,则输出-1,否则输出0。
代码:
public class Main{
public static void main(String[] args) {
// TODO Auto-generated method stub
String strA = "7.0.2";
String strB = "7.0.2";
strA = strA.replace(".", ",");
strB = strB.replace(".", ",");
String[] numA = strA.split(",");
String[] numB = strB.split(",");
int lenA = numA.length;
int lenB = numB.length;
int len = lenA>lenB? lenB : lenA;
int count = 0;
for(int i=0; i<len; i++){
int tempA = Integer.parseInt(numA
);
int tempB = Integer.parseInt(numB
);
if(tempA > tempB){
System.out.println(1);
return;
}else if(tempA < tempB){
System.out.println(-1);
return;
}else{
count++;
}
}
if(count == lenA && count == lenB){
System.out.println(0);
return;
}
if(lenA > lenB){
int res = 0;
for(int i = count; i<lenA; i++){
if(!numA
.equals("0")){
res = 1;
}
}
System.out.println(res);
}else if(lenA <= lenB){
int res = 0;
for(int i = count; i<lenB; i++){
if(!numB
.equals("0")){
res = -1;
}
}
System.out.println(-1);
}
}
}
---------------------
作者:另一个我竟然存在
来源:CSDN
原文:
https://blog.csdn.net/qq_24034545/article/details/82697025
版权声明:本文为博主原创文章,转载请附上博文链接!
作者:
不二晨
时间:
2018-11-28 15:46
奈斯
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2