JAVA学习第三周

判断某个字符串是否为回文

时间2019年9月23日下午

这个题有很多种写法,其一是用String来存这个字符串,然后调用charAt函数进行字符串的遍历,从两头开始遍历是否相等

其二是用toCharArray函数将String字符串转为char类型的数组直接用下标遍历。

我就是用的第二种

时间花费大概10+分钟

在几种方法中徘徊

源代码如下:

 
package shangke.disanzhou;

import java.util.Scanner;

public class ketangceshi01 {
static int flag=1;
static int n,m=0;
public int digui(char[] sss)
{
if(n==m||n-1==m)
{
return 0;
}
if(sss[n-1]!=sss[m])
{
flag=0;
}
n--;
m++;
return digui(sss);
} public static void main(String[] args) {
String sss;
ketangceshi01 sta=new ketangceshi01();
Scanner shuru=new Scanner(System.in);
sss=shuru.nextLine();
          //将String转化为char数组
char[] str=sss.toCharArray();
n=str.length;
sta.digui(str);
if(ketangceshi01.flag==1)
{
System.out.println("ture");
}
else
{
System.out.println("false");
} }
}

  JAVA学习第三周JAVA学习第三周

这个题目是练习递归调用的,递归调用一定要设好结束条件、递归参数。

我这个就是用静态的m、n来做计数器慢慢遍历整个数组,然后通过判断条件结束递归。

上一篇:celery+RabbitMQ 实战记录2—工程化使用


下一篇:椭圆曲线签名算法的v的定义