九度OJ--Q1165

来源:http://www.cnblogs.com/zlian2016/archive/2016/05/05/5463165.html
-Advertisement-
Play Games

import java.util.ArrayList;import java.util.Scanner; /* * 題目描述: * 讀入數據string[ ],然後讀入一個短字元串。要求查找string[ ]中和短字元串的所有匹配,輸出行號、匹配字元串。 * 匹配時不區分大小寫,並且可以有一個用中括 ...


import java.util.ArrayList;
import java.util.Scanner;

/*
 * 題目描述:
 * 讀入數據string[ ],然後讀入一個短字元串。要求查找string[ ]中和短字元串的所有匹配,輸出行號、匹配字元串。
 * 匹配時不區分大小寫,並且可以有一個用中括弧表示的模式匹配。如“aa[123]bb”,就是說aa1bb、aa2bb、aa3bb都算匹配。
 * 輸入:
 * 輸入有多組數據。
 * 每組數據第一行輸入n(1<=n<=1000),從第二行開始輸入n個字元串(不含空格),接下來輸入一個匹配字元串。
 * 輸出:
 * 輸出匹配到的字元串的行號和該字元串(匹配時不區分大小寫)。
 * 樣例輸入:
 * 4
 * Aab
 * a2B
 * ab
 * ABB
 * a[a2b]b
 * 樣例輸出:
 * 1 Aab
 * 2 a2B
 * 4 ABB
 */

public class q1165 {

  public static void main(String[] args) {
  
    Scanner scanner = new Scanner(System.in);
  
    while(scanner.hasNext()) {
   
      String n = scanner.nextLine();  

      int num = Integer.parseInt(n);
   
      String[][] str = new String[num][1];
      String mat = new String();
   
      // 保存用來匹配的字元串數據
      for(int i=0; i<num; i++)
        str[i][0] = scanner.nextLine();
      // 保存需要匹配的字元串數據
      mat = scanner.nextLine();
      char[] ch = mat.toCharArray();
   
      int x = 0, y = 0; // 用來保存'['和']'在字元數組ch中的位置
      int flag = 0; // 用來記錄是否存在'['和']',不存在flag=0,存在flag=1
      for(int i=0; i<ch.length; i++) {
        if(ch[i] == '[') {
          x = i;
          flag = 1;
          continue;
        }
        if(ch[i] == ']') {
          y = i;
          break;
        }
      }
   
      if(flag == 1) {
        // 用n個字元串分別匹配y-x-1個字元串
    
        for(int seq=1; seq<=y-x-1; seq++) {
     
          char[] chnew = new char[ch.length-(y-x+1)+1];
          int nn = 0;
          for(int m=0; m<ch.length-(y-x+1)+1; m++) {
      
            if(m == x) {
              chnew[m] = ch[nn+seq];
              nn = y + 1;
            }
            else {
              chnew[m] = ch[nn];
              nn++;
            }
          }
     
          for(int i=0; i<num; i++) {
      
            char[] target = str[i][0].toCharArray();
            int f = 0; // 判斷整個字元串是否全部匹配
      
            if(target.length == chnew.length) {
              for(int j=0; j<chnew.length; j++) {
                if((int)target[j]>=65 && (int)target[j]<=90) {
                  // 是大寫字母
                  if((int)target[j] == (int)chnew[j] || (int)target[j]+32 == (int)chnew[j]) {
                    f = 0;
                    continue;
                  }
                  else {
                    f = 1;
                    break;
                  }
                }
                else if((int)target[j]>=48 && (int)target[j]<=57) {
                  // 是數字
                  if((int)target[j] == (int)chnew[j]) {
                    f = 0;
                    continue;
                  }
                  else {
                    f = 1;
                    break;
                  }
                }
                else if((int)target[j]>=97 && (int)target[j]<=122) {
                  // 是小寫字母
                  if((int)target[j] == (int)chnew[j] || (int)target[j]-32 == (int)chnew[j]) {
                    f = 0;
                    continue;
                  }
                  else {
                    f = 1;
                    break;
                  }
                }
              }
            }
            else {
              continue;
            }
      
            if(f == 0) {
              System.out.print(i+1 + " ");
              for(int j=0; j<target.length; j++) {
                System.out.print(target[j]);
              }
              System.out.println();
            }
            else {
              continue;
            }
        
          }
     
        }
    
      }
      else {
        // 用n個字元串分別匹配ch
    
        for(int i=0; i<num; i++) {
     
          char[] target = str[i][0].toCharArray();
          int f = 0; // 判斷整個字元串是否全部匹配
     
          if(target.length == ch.length) {
            for(int j=0; j<ch.length; j++) {
              if((int)target[j]>=65 && (int)target[j]<=90) {
                // 是大寫字母
                if((int)target[j] == (int)ch[j] || (int)target[j]+32 == (int)ch[j]) {
                  f = 0;
                  continue;
                }
                else {
                  f = 1;
                  break;
                }
              }
              else if((int)target[j]>=48 && (int)target[j]<=57) {
                // 是數字
                if((int)target[j] == (int)ch[j]) {
                  f = 0;
                  continue;
                }
                else {
                  f = 1;
                  break;
                }
              }
              else if((int)target[j]>=97 && (int)target[j]<=122) {
                // 是小寫字母
                if((int)target[j] == (int)ch[j] || (int)target[j]-32 == (int)ch[j]) {
                  f = 0;
                  continue;
                }
                else {
                  f = 1;
                  break;
                }
              }
            }
          }
          else {
            continue;
           }
     
          if(f == 0) {
            System.out.print(i+1 + " ");
            for(int j=0; j<target.length; j++) {
              System.out.print(target[j]);
            }
            System.out.println();
          }
          else {
            continue;
          }
        }
      } 
    }
  }

}


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

-Advertisement-
Play Games
更多相關文章
  • 跨域訪問-需要設置HTTP響應標頭設置 前提:服務端網站的配置(被請求的網站) 1.需要在IIS伺服器站點的功能視圖中設置HTTP響應標頭: 2.雙擊“HTTP響應標頭”進入設置界面 3.點擊右側添加按鈕彈出視窗 4.填入需要設置的信息 名稱:Access-Control-Allow-Origin ...
  • 在開發中你是否遇到過當使用一個涉及到Cookie操作的網站或者管理系統時,IE 6、7、8、9下都跑的好好的,唯獨到了IE10、11這些高版本瀏覽器就不行了?那麼,我們就來看看,這個問題的前因後果。 先說下之前的2次使用場景: 第一次是在某頁面中,先存Cookie,然後再入庫記錄相關數據,但是發佈到 ...
  • 我們經常會在後臺定義一個變數,然後在用<%=變數名%>這種方式去獲取,但是有時候<head></head>裡面獲取變數的時候,有時候會獲取不到是怎麼回事呢 前臺: <head runat="server"> <%=test%> </head> 後臺: public partial class Org ...
  • 我 們知道並行編程模型兩種:一種是基於消息式的,第二種是基於共用記憶體式的。 前段時間項目中遇到了第二種 使用多線程開發並行程式共用資源的問題 ,今天以實際案例出發對.net里的共用記憶體式的線程同步機製做個總結,由於某些類庫的應用屬於基礎,所以本次不對基本使用做出講解,基本使用 MSDN是最好的教程。 ...
  • 用 Entity Framework 進行 增,刪,改。都是基於Model進行的,且Model都是有狀態追蹤的。這樣Entity Framework才能正常增,刪,改。 有時候,要根據某個欄位,批量更新或者刪除數據,用Entity Framework就會顯得很是繁瑣,且不高效。 Entity Fra ...
  • UDP特點: 面向無連接,把數據打包發過去,收不收得到我不管 數據大小有限制,一次不能超過64k,可以分成多個包 這是個不可靠的協議 速度很快 視頻直播,凌波客戶端,feiQ都是UDP協議 TCP特點: 面向連接,對方必須在 三次握手完成連接,我:在嗎;你:我在;我:我知道了 大數據量傳輸 速度稍慢 ...
  • 網路通信的步驟, 1.找到對方的ip 2.數據發送到對方指定的應用程式上,為了標識這些應用程式,用數字進行標識,這個數字就是埠 3.定義通信規則,這個規則就稱為協議 國際組織定義了通用協議 TCP/IP 網路模型 OSI參考模型 網路分成7層,應用層 ==> 表示層 ==> 會話層 ==> 傳輸層 ...
  • 今天我們來介紹一下C語言操作資料庫的方法,這裡我們使用的是ODBC方式。環境是WIN7+VC6。其他環境也差不多,具體情況具體分析。 首先是環境的配置以及數據源的添加。這裡就不去解釋了,相關資料網上有很多。需要註意的是這裡不可以直接使用控制面板中的ODBC,我們需要打開C:\Windows\SysW ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...