wyqrhx 2021-11-26 10:16 采纳率: 86.7%
浏览 43
已结题

一直显示找不到符号,问题出在哪?希望帮我解答


import java.util.*;//题目是求最长回文子串
public class Hwzc{
    public static void main(String[] args){
    Scanner sc=new Scanner(System.in);
    System.out.println("请输入字符串:");
    String str=sc.nextLine();
    String a=longestPalindrome(str);
        System.out.println(a);
    }
    public boolean Palindrome(String s){
        if(s==null)
        return false;
        int left=0;
        int right=s.length()-1;
        while(left<right){
            if(s.charAt(left)!=s.charAt(right))
                return false;
                left++;right--;
        }
        return true;
    }
        public static String longestPalindrome(String str){
        String zuichang=null;
        String tempString="";
        int max=0;
        for(int i=0;i<str.length();i++){
            for(int j=str.length()-1;j>i;j--){
                tempString=str.subStr( i, j+1);
                if(isPalindrome(tempString)&&(j-i+1)>max){
                    max=j-i+1;
                zuichang=str.subStr( i, j+1);
                }
            }
        }
        return zuichang;
        }
}//Hwzc.java:28: 错误: 找不到符号
                                tempString=str.subStr( i, j+1);
                                              ^
  符号:   方法 subStr(int,int)
  位置: 类型为String的变量 str
Hwzc.java:29: 错误: 找不到符号
                                if(isPalindrome(tempString)&&(j-i+1)>max){
                                   ^
  符号:   方法 isPalindrome(String)
  位置: 类 Hwzc
Hwzc.java:31: 错误: 找不到符号
                                zuichang=str.subStr( i, j+1);
                                            ^
  符号:   方法 subStr(int,int)
  位置: 类型为String的变量 str
3 个错误
  • 写回答

4条回答 默认 最新

  • xuyanqiangCode 2021-11-26 10:24
    关注
    package com.ihrm.demo;
    
    import java.util.*;//题目是求最长回文子串
    
    public class Hwzc {
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
            System.out.println("请输入字符串:");
            String str = sc.nextLine();
            String a = longestPalindrome(str);
            System.out.println(a);
        }
    
        public static boolean Palindrome(String s) {
            if (s == null)
                return false;
            int left = 0;
            int right = s.length() - 1;
            while (left < right) {
                if (s.charAt(left) != s.charAt(right))
                    return false;
                left++;
                right--;
            }
            return true;
        }
    
        public static String longestPalindrome(String str) {
            String zuichang = null;
            String tempString = "";
            int max = 0;
            for (int i = 0; i < str.length(); i++) {
                for (int j = str.length() - 1; j > i; j--) {
                    tempString = str.substring(i, j + 1);
                    if (Palindrome(tempString) && (j - i + 1) > max) {
                        max = j - i + 1;
                        zuichang = str.substring(i, j + 1);
                    }
                }
            }
            return zuichang;
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 12月4日
  • 已采纳回答 11月26日
  • 创建了问题 11月26日

悬赏问题

  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制