遍歷問題 codevs

来源:http://www.cnblogs.com/thmyl/archive/2016/12/11/6159962.html
-Advertisement-
Play Games

1029 遍歷問題 1029 遍歷問題 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 1029 遍歷問題 1029 遍歷問題 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 時間限制: 1 s 空間限制: 128000 ...


1029

遍歷問題

1029 遍歷問題

 時間限制: 1 s  空間限制: 128000 KB  題目等級 : 鑽石 Diamond 題目描述 Description

    我們都很熟悉二叉樹的前序、中序、後序遍歷,在數據結構中常提出這樣的問題:已知一棵二叉樹的前序和中序遍歷,求它的後序遍歷,相應的,已知一棵二叉樹的後序遍歷和中序遍歷序列你也能求出它的前序遍歷。然而給定一棵二叉樹的前序和後序,你卻不能確定其中序遍歷序列,考慮如下圖中的幾棵二叉樹:

 

    所有這些二叉樹都有著相同的前序遍歷和後序遍歷,但中序遍歷卻不相同。

輸入描述 Input Description

    輸入文件共2行,第一行表示該樹的前序遍歷結果,第二行表示該樹的後序遍歷結果。輸入的字元集合為{a-z},長度不超過26。

輸出描述 Output Description

    輸出文件只包含一個不超過長整型的整數,表示可能的中序遍歷序列的總數。

樣例輸入 Sample Input

abc

cba

樣例輸出 Sample Output

4

思路

只有一個兒子 的節點 才會在知道 前序後序 的情況下有不同的中序遍歷,所以將題目轉化成找 只有一個兒子的節點個數。

可以很容易的找出這類節點在前序後序中出現的規律。(前序中出現AB,後序中出現BA,則這個節點只有一個兒子)

每個這類節點有兩種中序遍歷(及兒子在左,兒子在右)根據乘法原理中序遍曆數為 2^節點個數 種

代碼

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
char qian[30];
char hou[30];
int ans=0;
int main()
{
    scanf("%s%s",qian,hou);
    for(int i=0;i<=strlen(qian)-1;i++)
        for(int j=1;j<=strlen(hou)-1;j++)
            if(qian[i]==hou[j]&&qian[i+1]==hou[j-1])
                ans++;
    printf("%d",1<<ans);
}

2010

求後序遍歷

2010 求後序遍歷

 

 時間限制: 1 s  空間限制: 64000 KB  題目等級 : 白銀 Silver       題目描述 Description

輸入一棵二叉樹的先序和中序遍歷序列,輸出其後序遍歷序列。

輸入描述 Input Description

 

共兩行,第一行一個字元串,表示樹的先序遍歷,第二行一個字元串,表示樹的中序遍歷。

輸出描述 Output Description

僅一行,表示樹的後序遍歷序列。

樣例輸入 Sample Input

abdehicfg

dbheiafcg

樣例輸出 Sample Output

dhiebfgca

數據範圍及提示 Data Size & Hint

輸入長度不大於255。

代碼

#include<iostream>
using namespace std;
int len;
string s1,s2;
void dfs(int s,int l,int r)
{
    if(l==r)return;
    int pos=l;
    for(int i=l;i<=r;i++)if(s1[s]==s2[i]){pos=i;break;}
    dfs(s+1,l,pos);
    dfs(s+pos-l+1,pos+1,r);
    cout<<s1[s];
}
int main()
{
    cin>>s1>>s2;
    len=s1.length();
    dfs(0,0,len);
}

3143

二叉樹的序遍歷

3143 二叉樹的序遍歷

 

 時間限制: 1 s  空間限制: 32000 KB  題目等級 : 白銀 Silver     題目描述 Description

求一棵二叉樹的前序遍歷,中序遍歷和後序遍歷

輸入描述 Input Description

第一行一個整數n,表示這棵樹的節點個數。

接下來n行每行2個整數L和R。第i行的兩個整數Li和Ri代表編號為i的節點的左兒子編號和右兒子編號。

輸出描述 Output Description

輸出一共三行,分別為前序遍歷,中序遍歷和後序遍歷。編號之間用空格隔開。

樣例輸入 Sample Input

5

2 3

4 5

0 0

0 0

0 0

樣例輸出 Sample Output

1 2 4 5 3

4 2 5 1 3

4 5 2 3 1

數據範圍及提示 Data Size & Hint

n <= 16

代碼

#include<iostream>
using namespace std;
int n;
struct node{
    int l,r;
}tree[20];
void dfs(int v)
{
    cout<<v<<' ';
    if(tree[v].l!=0)dfs(tree[v].l);
    if(tree[v].r!=0)dfs(tree[v].r);
}
void afs(int v)
{
    if(tree[v].l!=0)afs(tree[v].l);
    cout<<v<<' ';
    if(tree[v].r!=0)afs(tree[v].r);
}
void cfs(int v)
{
    if(tree[v].l!=0)cfs(tree[v].l);
    if(tree[v].r!=0)cfs(tree[v].r);
    cout<<v<<' ';
}
int main()
{
    cin>>n;
    int x,y;
    for(int i=1;i<=n;i++)
    {
        cin>>x>>y;
        tree[i].l=x;
        tree[i].r=y;
    }
    dfs(1);cout<<endl;
    afs(1);cout<<endl;
    cfs(1);
}

 

 

 

 

 

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 設計模式(Design Patterns) ——可復用面向對象軟體的基礎 設計模式(Design pattern)是一套被反覆使用、多數人知曉的、經過分類編目的、代碼設計經驗的總結。使用設計模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。 毫無疑問,設計模式於己於他人於系統都是多贏的, ...
  • 需求:使用IO流將一個文件的內容複製到另外一個文件中去 文件"good boy.txt"位於D盤根目錄下,要求將此文件的內容複製到c:\\myFile.txt中 代碼: import java.io.*; public classInputAndOutputFile{ public static v ...
  • An internal error occurred during: "Initializing Java Tooling".java.lang.NullPointerException ...
  • String擁有一個特殊點叫:String對象的內容不可改變! 在調用諸如String對象的replace()等方法時,不是在原Sting對象的基礎上改變對象內容,而是創建了一個新的String對象把調用的方法後返回的結果放在這個新的String對象中 代碼示例如下: String str3 = " ...
  • ... ...
  • 為什麼需要線程同步? 同步就是協同步調,按預定的先後次序進行運行。如:你說完,我再說而並非一起動作。“同”字應是指協同、協助、互相配合。 如進程、線程同步,可理解為進程或線程A和B一塊配合,A執行到一定程度時要依靠B的某個結果,於是停下來,示意B運行;B依言執行,再將結果給A;A再繼續操作。 所謂同 ...
  • 吞吐量是指,應用程式的TPS: 每秒多少次事務,QPS: 每秒多少次查詢等性能指標。 吞吐量調優就是減少垃圾收集器消耗的CPU周期數,從而將更多的CPU周期用於執行應用程式。 CMS吞吐調優 CMS包括Minor GC所帶來的開銷應該小於10%,如果垃圾收集的開銷在3%或更少,說明通過調優吞吐量,提 ...
  • 人機猜拳是我自己原創的一段代碼,我剛學完do-while,知識有限,但自己感覺寫的這段代碼是我的一個小巔峰,發出來讓大家看看,新手能學到東西的話是極好的,然後更多的是想讓一些老鳥給點建議。這個寫代碼很枯燥,最近一直在寫,自己是深有體會,後來我就在練習的時候在自己的代碼里寫一些有趣的內容,下麵你們能看 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...