博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
回文字符串问题
阅读量:6302 次
发布时间:2019-06-22

本文共 3181 字,大约阅读时间需要 10 分钟。

一、判断一个字符串是否为回文字符串(aba)

public static boolean is_hwzfs(String s, int i, int j) {        if (i > j) return false;        for (int k = i; k <= j; ++k) {            if (s.charAt(k) != s.charAt(j + i - k)) {                return false;            }        }        return true;    }

二、求一个字符串的最长回文字符串长度并输出

1)暴力枚举

1 public static boolean is_hwzfs(char[] s, int i, int j) { 2         if (i > j) return false; 3         for (int k = i; k <= j; ++k) { 4             if (s[k] != s[j + i - k]) { 5                 return false; 6             } 7         } 8         return true; 9     }10 11     public static void main(String[] args) {12 13         Scanner cin = new Scanner(System.in);14         String s = cin.nextLine();15 16         int len = s.length();17         int max = 1;18         int x = 0, y = 0;19         int[] p = new int[len];20         char[] ans = new char[len];21         int index = -1;22         for (int i = 0; i < len; ++i) {23             char ch = s.charAt(i);24             if (Character.isLetter(ch)) {25                 p[++index] = i;26                 ans[index] = Character.toLowerCase(ch);27             }28         }29 30 31         for (int i = 0; i <= index; ++i) {32             for (int j = i; j <= index; ++j) {33                 if (is_hwzfs(ans, i, j)) {34                     if (max < (j - i + 1)) {35                         max = j - i + 1;36                         x = p[i];37                         y = p[j];38                     }39                 }40             }41         }42         System.out.println("max= " + max);43         for (int i = x; i <= y; ++i) {44             System.out.print(s.charAt(i));45         }46         System.out.println();47     }

 

2)确定字符串中心,向两边扩展枚举

  1. 长度为奇数:  判断 s[i-j]与s[i+j]  (2*j+1)
  2. 长度为偶数:判断 s[i-j]与 s[i+j+1] (2*(j+1))

注意 i为字符串中心,j为向两边扩展的长度

法一:

法二:

public static void main(String[] args) {        Scanner cin = new Scanner(System.in);        String s = cin.nextLine();        int len = s.length();        int max = 1;        int x = 0, y = 0;        int[] p = new int[len];        char[] ans = new char[len];        int index = -1;        for (int i = 0; i < len; ++i) {            char ch = s.charAt(i);            if (Character.isLetter(ch)) {                p[++index] = i;                ans[index] = Character.toLowerCase(ch);            }        }        for (int i = 0; i <= index; ++i) {            for (int j = 0; (i - j > 0) && (i + j <= index); ++j) {                if (ans[i - j] != ans[i + j]) break;                if ((2 * j + 1) > max) {                    x = p[i - j];                    y = p[i + j];                    max = 2 * j + 1;                }            }            for (int j = 0; (i - j > 0) && (i + j + 1 <= index); ++j) {                if (ans[i - j] != ans[i + j + 1]) break;                if (2 * (j + 1) > max) {                    x = p[i - j];                    y = p[i + j + 1];                    max = 2 * (j + 1);                }            }        }        System.out.println("max= "+max);        for (int i = x; i <= y; ++i) {            System.out.print(s.charAt(i));        }        System.out.println();    }

 

转载于:https://www.cnblogs.com/dmir/p/5836876.html

你可能感兴趣的文章
uva 10801 - Lift Hopping(最短路Dijkstra)
查看>>
[Java Web]servlet/filter/listener/interceptor区别与联系
查看>>
POJ 2312Battle City(BFS-priority_queue 或者是建图spfa)
查看>>
从零开始学MVC3——创建项目
查看>>
CentOS 7 巨大变动之 firewalld 取代 iptables
查看>>
延时任务和定时任务
查看>>
linux下的权限问题
查看>>
教你如何使用Flutter和原生App混合开发
查看>>
Spring Boot 整合redis
查看>>
CSS hover改变背景图片过渡动画生硬
查看>>
JDBC(三)数据库连接和数据增删改查
查看>>
淘宝应对"双11"的技术架构分析
查看>>
ssh
查看>>
订单的子单表格设置颜色
查看>>
Office365 Exchange Hybrid 番外篇 ADFS后端SQL群集(一)
查看>>
9个offer,12家公司,35场面试,从微软到谷歌,应届计算机毕业生的2012求职之路...
查看>>
lvs fullnat部署手册(三)rs内核加载toa篇
查看>>
C++策略模式
查看>>
我的友情链接
查看>>
oracle表分区详解
查看>>