黑马程序员技术交流社区
标题:
关于判断字符串是否对称的问题
[打印本页]
作者:
雀巢咖啡
时间:
2014-4-15 23:30
标题:
关于判断字符串是否对称的问题
判断一个字符串是否是对称字符串,例如"abc"不是对称字符串。
一下是我自己写的代码:
import java.util.*;
public class test2 {
public static void main(String[] args)
{
Scanner in=new Scanner(System.in);
String s=in.next();//输入字符串
int max=s.length();//获取字符串的长度
int index=0;//定义一个标记,用来判断字符串中对应位置是否有不相同的字符。
for(int i=0;i<max;i++)
{
if(s.charAt(i)!=s.charAt(max-i-1))
{
index++;
break;
}
else
{
continue;
}
}
if(index>0)
{
System.out.println("这个字符串不是对称的");
}
else
{
System.out.println("这个字符串是对称的");
}
}
}
如果不定义index,该如何修改代码。(不要告诉我直接调用java类库中的函数方法);
作者:
ノtrack
时间:
2014-4-15 23:53
不可以用java类库的方法么?
作者:
马上都有
时间:
2014-4-16 00:29
ノtrack 发表于 2014-4-15 23:53
不可以用java类库的方法么?
import java.util.*;
public class test2 {
public static void main(String[] args)
{
Scanner in=new Scanner(System.in);
String s=in.next();//输入字符串
int max=s.length();//获取字符串的长度
//int index=0;//定义一个标记,用来判断字符串中对应位置是否有不相同的字符。
for(int i=0;i<max;i++)
{
if(s.charAt(i)!=s.charAt(max-i-1))
{
System.out.println("这个字符串不是对称的");
//index++;
break;
}
else if(i==max-i)
{
System.out.println("这个字符串是对称的");
}
else
continue;
}
}
}
//楼主深夜为你效劳,代码已改好,期望有技术分拿。
作者:
马上都有
时间:
2014-4-16 00:31
import java.util.*;
public class test2 {
public static void main(String[] args)
{
Scanner in=new Scanner(System.in);
String s=in.next();//输入字符串
int max=s.length();//获取字符串的长度
//int index=0;//定义一个标记,用来判断字符串中对应位置是否有不相同的字符。
for(int i=0;i<max;i++)
{
if(s.charAt(i)!=s.charAt(max-i-1))
{
System.out.println("这个字符串不是对称的");
//index++;
break;
}
else if(i==max-i)
{
System.out.println("这个字符串是对称的");
}
else
continue;
}
}
}
//楼主深夜为你效劳,代码已改好,期望有技术分拿。
作者:
清风夜独醉
时间:
2014-4-16 03:25
只需要在for循环比较到中间两个字符的时候,加个if语句判断一下是否仍然相同,是的话就打印输出这个字符串是对称的。修改后的代码如下:
public class Test2 {
public static void main(String args[]) {
Scanner in = new Scanner(System.in);
String s = in.next();// 输入字符串
int max = s.length();// 获取字符串的长度
for (int i = 0; i <= max/2; i++) {
if (s.charAt(i) != s.charAt(max - i - 1)) {
System.out.println("这个字符串不是对称的");
break;
}else if(i == max/2)
System.out.println("这个字符串是对称的");
}
}
}
复制代码
作者:
创造命运
时间:
2014-4-16 07:09
本帖最后由 创造命运 于 2014-4-16 07:14 编辑
下面是我写的,应该是达到你的要求了。你可以看看:
import java.util.*;
public class Test{
public static void main(String[] args)
{
Scanner in=new Scanner(System.in);
String s=in.next();//输入字符串
int max=s.length();//获取字符串的长度
for(int i = 0; i < max/2; i++) //只需要循环max/2或者max/2-1次
{
if(s.charAt(i)!=s.charAt(max-1-i))
{
System.out.println("这个字符串不是对称的");
break;
}
else
{
//如果i == max/2或者i == max/2-1那就表示所有对应的字符都是对称的
if (i == max/2 || i == max/2-1)
{
System.out.println("这个字符串是对称的"); break;
}
}
}
}
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2