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 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi