對輸入的字元串測試其是否為迴文

来源:https://www.cnblogs.com/zxysaigao/archive/2018/03/24/8641904.html
-Advertisement-
Play Games

如果一個字元串去掉除字母和數字之外的所有字元後,正讀和逆讀都一樣,則這個字元串就是一個迴文。例如:“did Anna say as Anna did?”就是迴文。 編程:要求對輸入的字元串測試其是否為迴文。 1 class Palindrome{ 2 3 public static void mai ...


如果一個字元串去掉除字母和數字之外的所有字元後,正讀和逆讀都一樣,則這個字元串就是一個迴文。例如:“did Anna say as Anna did?”就是迴文。

編程:要求對輸入的字元串測試其是否為迴文。

 1 class Palindrome{
 2 
 3  public static void main(String[] args){
 4 
 5          Scanner sc = new Scanner(System.in);
 6 
 7          System.out.println(“please input a string:”);
 8 
 9     String strInput = sc.nextLine();
10 
11          if(isPalind(strInput)){
12 
13               System.out.println("\""+strInput+"\" "+"是迴文!");
14 
15 }else{
16 
17               System.out.println("\""+strInput+"\" "+"不是迴文!");
18 
19 }
20 
21 }
22 
23 public static boolean isPalind(String s){
24 
25          String s1 = filter(s); //過濾掉s中字母和數字外的字元
26 
27          String s2 = reverse(s1);//將s1串反轉
28 
29          retrun  s1.equals(s2);
30 
31 }
32 
33 public static String filter(String s){
34 
35    //將方法補充完整
36 
37 
38 }
39 
40 public static String reverse(String s){
41 
42    //將方法補充完整
43 
44 }
45 
46 }
47 
48  
View Code

解如下:

 1 package zy.pg.ex3;
 2 
 3 import java.util.*;
 4 
 5 public class Experiment_3_Palindrome {
 6 
 7     public static void main(String[] args) {
 8         // TODO Auto-generated method stub
 9         Scanner sc = new Scanner(System.in);
10         System.out.println("please input a string:");
11         String strInput = sc.nextLine();
12         if (isPalind(strInput)) {
13             System.out.println("\"" + strInput + "\" " + "是迴文!");
14         } else {
15             System.out.println("\"" + strInput + "\" " + "不是迴文!");
16         }
17 
18     }
19 
20     private static boolean isPalind(String s) {
21         // TODO Auto-generated method stub
22         String s1 = filter(s); //過濾掉s中字母和數字外的字元
23         String s2 = reverse(s1);//將s1串反轉
24         return  s1.equals(s2);
25 
26     }
27     public static String filter(String s){
28            //將方法補充完整
29         StringBuffer f = new StringBuffer();
30         char[] s1 = s.toCharArray();
31         int flag = 0;
32         for(int i = 0; i < s1.length; i++) {
33             if((s1[i] <= '9' && s1[i] >= '0') || (s1[i] >= 'a' && s1[i] <= 'z') || (s1[i] >= 'A' && s1[i] <= 'Z'))
34                 f.insert(flag++, s1[i]);
35         }
36         String news = new String(f);
37         return news;
38     }
39     public static String reverse(String s){
40            //將方法補充完整
41         return new StringBuilder(s).reverse().toString();
42     }
43 }
View Code

第一個方法filter是先想到能不能創建一個字元串,然後將篩選下來的字元逐個銜接在字元串後邊,即可得到篩選後的字元串。但是在網上搜到了JAVA竟然有字元串變數這個數據類型,並且有銜接字元的方法。簡直是再好不過了。

聲明格式跟其他數據類型一樣,但是我學到了一個新的聲明類型。

1 String s;  
2 String b;  
3 StringBuffer sb = new StringBuffer(b);  
4 sb.insert(0,s); 

這是網上搜來的例子。insert方法的第一個參數為插入位置的起始位置。第二個參數為要插入的字元串,但我在使用中用的是字元,我猜改方法是將字元看作字元串處理的。

並且學到了將字元串常量與字元串變數互轉的方法。上邊代碼表示了字元串常量轉化為字元串變數。相反類似。

這種轉化法我就暫且命名為構造方法轉化法吧。(嘻嘻,可能已經有這個說法了吧,我還沒聽到過)

然後

就是字元串的倒置了。要用到一個方法。

1 public static String reverse(String str){  
2         return new StringBuilder(str).reverse().toString();  
3 }

這也是在網上看到的。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • hi.py 的提供的路由裝飾器接受兩個參數,第一個參數指定動態路由的正則模式,第二個參數指定同意的http請求方法列表。 比如: 這個路由指定uri為/client或者/client/,同時請求方法為GET或者POST的http請求由函數client(req,res,param)來處理。uri模式由 ...
  • 看了很多關於捲積的介紹,一直感覺不怎麼理解,今天徹底研究下: 我們知道圖像是由像素構成的,圖像中的行和列一起構成了圖像矩陣,比如一個解析度800*400的圖像,同時也是一個大矩陣,這個矩陣有著400行和800列.假設有一個3*3的濾波小矩陣(捲積核), 在進行捲積運算的時候,我們便利整個圖像大矩陣中 ...
  • yum install gcc libffi-devel python-devel openssl-devel ...
  • 首發日期:2018-03-24 final關鍵字: final的作用:相當於使修飾的變數、方法或類“固定、最終化”,使得修飾的變數、方法、類不能再做改變【可以限制繼承的重寫】。 final可以修飾類、方法、變數。 final修飾的類不可以被繼承。 final修飾的方法不可以被覆蓋(重寫) final... ...
  • C++字元串string類 在C語言里,字元串是用字元數組來表示的,而對於應用層而言,會經常用到字元串,而繼續使用字元數組,就使得效率非常低. 所以在C++標準庫里,通過類string從新自定義了字元串。 頭文件: #include <string> string直接支持字元串連接 string直接 ...
  • 在使用vector容器的時候,需要將一個vector中的內容複製到另一個vector結尾,如何實現呢? 使用vector的insert方法 參數解釋: position:元素在容器中插入的位置,iteratior是一種成員類型,定義為指向元素的隨機訪問迭代器類型。 first,last:iterat ...
  • 在別人代碼里,經常看到std命名空間,比如使用std命名空間里的標準輸入輸出流對象cout: 其中cout相當於控制台輸出(console out),然後通過<<左移操作符,將每個字元列印出來. endl相當於就是'\n'換行. 接下來我們便通過上章學習的操作符重載,來實現上面功能 上面的操作符重載 ...
  • 項目背景 每個系統都有日誌,當系統出現問題時,需要通過日誌解決問題 當系統機器比較少時,登陸到伺服器上查看即可滿足 當系統機器規模巨大,登陸到機器上查看幾乎不現實 當然即使是機器規模不大,一個系統通常也會涉及到多種語言的開發,拿我們公司來說,底層是通過c++開發的,而也業務應用層是通過Python開 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...