02-線性結構4 Pop Sequence

来源:https://www.cnblogs.com/biankun/archive/2018/03/14/8570270.html
-Advertisement-
Play Games

中國大學MOOC-陳越、何欽銘-數據結構-2018春 第二講課後習題第四題 ...


  這道題是2013年PAT春季考試真題,考察隊堆棧的基本概念的掌握。在保證輸入正確後,關鍵在於對"Pop"序列的判斷,我用isPopOrder函數進行了判斷,代碼如下:

#include <stdio.h>
#include <stdlib.h>
#define MaxSize 1001

typedef struct SNode *Stack;
struct SNode{
    int Data[MaxSize];
    int MaxCap;  //Maximum capacity of this stack
    int Top;
};

Stack CreateStack(int M)
{
    Stack PtrS;
    PtrS = (Stack)malloc(sizeof(struct SNode));
    PtrS->Top = -1;
    PtrS->MaxCap = M;
    return PtrS;
}

/*堆棧基本操作此處略去*/

int isPopOrder(int *CheckOrder, int M, int N, int K)
{
    int i, ci = 0;
    Stack S;
    S = CreateStack(M);
    for(i = 1; i < N + 1; i++){
        Push(i, S);  //Push in the order of 1, 2, ..., N
        while(CheckOrder[ci] == GetTop(S)){
            Pop(S);
            ci++;
        }
    }
    if(GetTop(S) == -1)  //堆棧為空
        return 1;
    else
        return 0;
}

int main(int argc, char const *argv[])
{
    int M, N, K;  //M is the maximum capacity of the stack; Push N numbers; K sequences to be checked
    int i, j;
    int CheckOrder[MaxSize], res[MaxSize];
    scanf("%d %d %d", &M, &N, &K);
    for(i = 0; i < K; i++){
        for(j = 0; j < N; j++){
            scanf("%d", &CheckOrder[j]);
        }
        res[i] = isPopOrder(CheckOrder, M, N, K);
    }
    for(i = 0; i < K; i++){
        if(res[i])
            printf("YES\n");
        else
            printf("NO\n");
    }
    return 0;
}

(待更新)


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

-Advertisement-
Play Games
更多相關文章
  • 1.在pom.xml中使用spring-boot-starter-parent的作用: Maven users can inherit from the spring-boot-starter-parent project to obtain sensible defaults. The paren ...
  • 內容:通過修改hosts文件,讓pycharm不能夠聯網驗證激活碼的方式 1、修改hosts文件 文件位置:C:\Windows\System32\drivers\etc 在文件末尾添加:0.0.0.0 account.jetbrains.com 如圖: 2、打開PyCharm,選擇 Activat ...
  • 某地區經過對城鎮交通狀況的調查,得到現有城鎮間快速道路的統計數據,並提出“暢通工程”的目標:使整個地區任何兩個城鎮間都可以實現快速交通(但不一定有直接的快速道路相連,只要互相間接通過快速路可達即可)。現得到城鎮道路統計表,表中列出了任意兩城鎮間修建快速路的費用,以及該道路是否已經修通的狀態。現請你編 ...
  • 以下基本不是原創,都是轉載。 JVM運行時,首先需要類載入器(ClassLoader) 載入所需類的位元組碼,載入完畢交由執行引擎執行,執行過程中需要一段空間來存儲數據(類比CPU與主存)。這段記憶體空間的分配和釋放過程正是我們所關心的,稱為運行時數據區。 運行時數據區 如上圖所示,運行時數據區包括:程 ...
  • 1.創建變數; 2.使用不同類型的變數; 3.在變數中存儲值; 4.在數學表達式中使用變數; 5.把一個變數的值賦給另一個變數; 6.遞增/遞減變數的值。 程式Variable:使用不同類型的變數並賦初值 1 package com.jsample; 2 3 public class Variabl ...
  • AOP:面向切麵編程,就是把除去業務部分以外的東西單獨模塊化,比如打日誌等,就像學生信息的增刪改查,可以把輸出日誌單獨模塊化出來,通過切麵對的方式進行編程。 在進行實例編寫之前先進行一些專業術語的瞭解 切麵aspect:是對象操作過程中的截面,是一段代碼,實現額外的模塊化功能 連接點join poi ...
  • Spring Boot已成為當今最流行的微服務開發框架,本文是如何使用Spring Boot快速開始Web微服務開發的指南,我們將使創建一個可運行的包含內嵌Web容器(預設使用的是Tomcat)的可運行Jar包。 傳統的Spring應用程式需要配置大量的XML文件才能運行,而使用Spring Boo ...
  • 一、前言 1.1.環境 python版本:3.6 Django版本:1.11.6 1.2.預覽效果 最終搭建的blog的樣子,基本上滿足需求了。框架搭好了,至於CSS,可以根據自己喜好隨意搭配。 二、建立博客應用 2.1.建立項目和應用 創建工程blogproject 創建blog應用 打開 blo ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...