華為筆試——C++括弧匹配

来源:https://www.cnblogs.com/ljy1227476113/archive/2018/09/13/9644075.html
-Advertisement-
Play Games

題目:括弧匹配 題目來源:https://blog.csdn.net/lizi_stdio/article/details/76618908 題目介紹:輸入一個字元串,裡面可能包含“()”、“ [ ] ”、" { } "三種括弧,要求程式判斷這個字元串里的括弧是否成對出現且嵌套關係正確,若成對出現且 ...


題目:括弧匹配

題目來源:https://blog.csdn.net/lizi_stdio/article/details/76618908

題目介紹:輸入一個字元串,裡面可能包含“()”、“ [  ] ”、" {  } "三種括弧,要求程式判斷這個字元串里的括弧是否成對出現且嵌套關係正確,若成對出現且嵌套關係正確,或字元串中無括弧出現時,輸出True;否則輸出False。無需考慮非法輸入。

例:

輸入:

(1+4)/[(2+3)*4]

輸出:

True

分析:這個問題考察的其實是棧的問題。因為若要成對出現且嵌套關係正確,就必須滿足最後的“(”後的下一個括弧必須是“)”,否則就不正確,其他兩種括弧同理。在前面出現的“ [ ”後出現的可能是“(”或者是“ ] ”,因此需要用到棧來解決。若出現左括弧則進棧,遇到下一個右括弧則與棧中比較,若匹配則出棧進行下一個比對。這樣直到末尾,若棧空則輸出True,否則輸出False即可。

代碼:(轉載,鏈接放在文章開頭,寫的真的很好)

 1 #include <iostream>
 2 #include <cstring>
 3 #include <string>
 4 #include <map>
 5 #include <vector>
 6 #include <algorithm>
 7 using namespace std;
 8 
 9 bool isLeft(char a)
10 {
11     return (a == '(') || (a == '[') || (a == '{');
12 }
13 
14 bool isRight(char a)
15 {
16     return (a == ')') || (a == ']') || (a == '}');
17 }
18 
19 bool isMatch(char a, char b)
20 {
21     if (a == '('&&b == ')')
22     {
23         return true;
24     }
25     else if (a == '['&&b == ']')
26     {
27         return true;
28     }
29     else if (a == '{'&&b == '}')
30     {
31         return true;
32     }
33     return false;
34 }
35 
36 int main()
37 {
38 #if 0
39     freopen("in.txt", "r", stdin);
40     //freopen("out.txt", "w", stdout);
41 #endif
42     string str;
43     vector<char> cvec;
44     cvec.reserve(200);
45     while (cin >> str)
46     {
47         auto iter = str.begin();
48         for (; iter != str.end(); ++iter)
49         {
50             //左括弧直接進棧
51             if (isLeft(*iter))
52             {
53                 cvec.push_back(*iter);
54             }
55             //如果出現右括弧
56             else if (isRight(*iter))
57             {
58                 //不合理情況1: 棧空的話,直接退出    這裡情況一開始忘記考慮,但是華為機試仍然100%通過
59                 if (cvec.empty())
60                 {
61                     break;
62                 }
63                 char c = cvec.back();
64                 cvec.pop_back();
65                 //不合理情況2:判斷棧中左括弧與現在的右括弧是否匹配
66                 if (!isMatch(c, *iter))
67                 {
68                     break;
69                 }
70             }
71         }
72         //處理不合理情況1,2  以及不合理情況3:字元已經遍歷結束,但是棧仍然非空
73         if (iter != str.end() || !cvec.empty())
74         {
75             cout << "false" << endl;
76         }
77         else
78         {
79             cout << "true" << endl;
80         }
81     }
82     return 0;
83 }

結果:

 


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

-Advertisement-
Play Games
更多相關文章
  • 在前兩次的 cicada 版本中其實還不支持讀取配置文件,比如對埠、路由的配置。 因此我按照自己的想法創建了一個 issue ,也收集到了一些很不錯的建議。 ...
  • 一個人知道的Topic是單點推送,大家都知道Topic是廣播。 kafka消息消費機制: 1.廣播消費:通過定義topic首碼來標識屬於廣播的消息(例如:topicname:gonggao1535680698557,gonggao1535680722624,gonggao1535681677381等 ...
  • 前陣子,我們分享了《 "Java中的基本數據類型轉換" 》這篇文章,對許多粉絲還是有帶來幫助的,今天講一下 Java 包裝類的的由來,及自動裝箱、拆箱的概念和原理。 什麼是包裝類型 Java 設計當初就提供了 8 種 基本數據類型及對應的 8 種包裝數據類型。我們知道 Java 是一種面向對象編程的 ...
  • 一.緩存雪崩現象 緩存雪崩一般是由某個緩存節點失效,導致其他節點的緩存命中率下降, 緩存中缺失的數據去資料庫查詢,短時間內造成資料庫伺服器崩潰, 重啟DB短期又被壓跨,但新數據的緩存也更新一些,DB反覆多次啟動多次,緩存重建完畢,DB才穩定運行,或者是由於緩存周期性的失效,比如緩存失效周期相同,在一 ...
  • c/c++ 標準容器 vector的記憶體空間是如何自動增長的 vector,string,deque的記憶體存儲機制:在一個連續的記憶體空間存儲,所以才支持下標操作。 vector的課題:由於容器的大小是可變的,當插入元素後,vector必須分配新的記憶體來保存已有元素和新的元素,將已有元素從舊的記憶體地址 ...
  • 版權聲明:本文為博主原創文章,未經允許不得轉載 引子 平常的文本處理工作中,我經常會遇到這麼一種情況:用python判斷一個string是否包含一個list里的元素。 這時候使用python的內置函數any()會非常的簡潔: any() 其實any函數非常簡單:判斷一個tuple或者list是否全為 ...
  • 單例概述 單例意即類在整個工程里只能有一個實例。單例通常應用在如下場景中,類的構造是一個非常耗時的過程,並且,它沒有多次構造的必要性。例如。你可以打開一個資料庫連接,只在此連接上進行資料庫操作。 那麼怎確保它在整個工程中只有一個實例呢?我們可以通過將構造函數的訪問許可權設置為private,並輔助其它 ...
  • java基礎: 1、==和equals的區別: 基本類型和引用類型 ==用來比較值,equals是比較對象的引用,即是否指向同一個對象? String str1 = new String("hello");String str2 = new String("hello"); System.out.p ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...