天梯賽DFS合集

1.DFS+特殊輸入:PTA | 程序設計類實驗輔助教學平臺

這題其他還是蠻容易,直接用遞歸即可,問題在于怎么輸入,其實可以在遞歸到底層時輸入即可,也就是邊遞歸邊輸入,另外提一嘴跟這個題沒什么關系的點(string.find找不到時返回String::npos,同時在從莫個下標開始找是find(str,pos))具體見AC代碼:

#include<bits/stdc++.h>
using namespace std;
int ru[200010];
int n;
vector<int> edge[200100];
int shu[200010];
int dfs(int root){if(root==0){char c;cin>>c;return int(c-'0');}if(shu[root]==1){int f=1;int x1=dfs(edge[root][0]);int x2=dfs(edge[root][1]);if(x1==1&&x2==1) f=1;else f=0;return f;}if(shu[root]==2){int f=0;int x1=dfs(edge[root][0]);int x2=dfs(edge[root][1]);if(x1==1||x2==1) f=1;else f=0;return f;}if(shu[root]==3){return 1-dfs(edge[root][0]);}
}
int main(){cin>>n;for(int i=1;i<=n;i++){int x;cin>>x;shu[i]=x;if(x==3){int u;cin>>u;ru[u]++;edge[i].push_back(u);}else{int u,v;cin>>u>>v;ru[u]++;ru[v]++;edge[i].push_back(u);edge[i].push_back(v);}}int root;for(int i=1;i<=n;i++){if(ru[i]==0) root=i;}//cout<<root<<endl;int k;cin>>k;while(k--){int ans=dfs(root);if(ans==0) cout<<"BuAi";else cout<<"Ai";if(k!=0) cout<<endl;}
}

2.DFS+剪枝:PTA | 程序設計類實驗輔助教學平臺

看到數字這么小顯然就是DFS暴力,但是直接爆搜鐵TLE,考慮優化:

實際上,我們只需要枚舉內嵌一層的矩形即可,因為最后一個可以直接推出來,因此我們需要在維護一個行和列的前綴和數組。下面是AC代碼:

#include<bits/stdc++.h>
using namespace std;
int l,n;
int a[20][20];
int sumx[20],sumy[20];
int cnt=0;
bool check(){int sum1=0,sum2=0;for(int i=1;i<=n-1;i++) sum1+=l-sumx[i];for(int i=1;i<=n-1;i++) sum2+=l-sumy[i];if((l-sum1)>=0&&sum1==sum2) return 1;return 0;
}
void dfs(int x,int y){if(y==n-1){int xx=l-sumx[x];if(xx<0) return;}if(x==n-1){int yy=l-sumy[y];if(yy<0) return;}if(x==n-1&&x==y){if(check()==1) cnt++;return;}if(y==n-1){y=1;x++;}else{y++;}for(int i=0;i<=min(l-sumx[x],l-sumy[y]);i++){a[x][y]=i;sumx[x]+=i;sumy[y]+=i;dfs(x,y);sumx[x]-=i;sumy[y]-=i;}return;
}
int main(){cin>>l>>n;for(int i=0;i<=l;i++){a[1][1]=i;sumx[1]=sumy[1]=i;dfs(1,1);}cout<<cnt;
}

3.DFS+剪枝:PTA | 程序設計類實驗輔助教學平臺

這題比較正常的想法就是先枚舉順序,但是這樣也會TLE,其實我們可以邊枚舉邊檢查,檢查到不對了就直接退出,也就是進行一下剪枝,具體見AC代碼:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<int,int> pii;
const int inf=0x3f3f3f3f;
const int maxn=1e6+5;
int n,m;
vector<int> v[maxn], v1;
bool vis[maxn];
int h[maxn];
void dfs(int x){//x是當前紙條的下標if(x==n-1){//終止條件for (int i = 0; i < v1.size();i++){//遍歷輸出if(i)cout << " ";cout << v1[i];}}for (int i = 1; i <= m; i++){if(!vis[i]){//當前紙條未使用過int flag = 1;for (int j = 0; j < v[i].size();j++){if(v[i][j]!=h[x+j])flag = 0;//不滿足題意}if(flag){v1.push_back(i);vis[i] = 1;dfs(x + v[i].size() - 1);vis[i] = 0;//回溯v1.pop_back();//回溯}}}
}
void solve(){cin >> n;for (int i = 0;i<n;i++){cin >> h[i];}cin >> m;for (int i = 1;i<=m;i++){int k, x;cin>>k;while(k--){cin>>x;v[i].push_back(x);}}dfs(0);
}
int main(){solve();
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/79484.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/79484.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/79484.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

使用Pydantic優雅處理幾何數據結構 - 前端輸入驗證實踐

使用Pydantic優雅處理幾何數據結構 - 前端輸入驗證實踐 一、應用場景解析 在視頻分析類項目中&#xff0c;前端常需要傳遞幾何坐標數據。例如智能安防系統中&#xff0c;需要接收&#xff1a; 視頻流地址&#xff08;rtsp_video&#xff09;檢測區域坐標點&#xff08;point…

智譜AI大模型免費開放:開啟AI創作新時代

文章摘要&#xff1a;近日&#xff0c;國內領先的人工智能公司智譜AI宣布旗下多款大模型服務免費開放&#xff0c;這一舉措標志著大模型技術正式邁入普惠階段。本文將詳細介紹智譜AI此次開放的GLM-4 等大模型&#xff0c;涵蓋其主要功能、技術特點、使用步驟以及應用場景&#…

JMeter中設置HTTPS請求

在JMeter中設置HTTPS請求&#xff0c;你可以按照以下步驟進行操作&#xff1a; 步驟一&#xff1a;添加線程組 打開JMeter后&#xff0c;右鍵點擊“測試計劃”&#xff0c;選擇“添加” -> “線程&#xff08;用戶&#xff09;” -> “線程組”。線程組用于定義虛擬用戶…

線程池七個參數的含義

Java中的線程池里七個參數的以及其各自的含義 面試題&#xff1a;說一下線程池七個參數的含義&#xff1f; 所謂的線程池的 7 大參數是指&#xff0c;在使用 ThreadPoolExecutor 創建線程池時所設置的 7 個參數&#xff0c;如以下源碼所示&#xff1a; public ThreadPoolExe…

【最后203篇系列】028 FastAPI的后臺任務處理

說明 今天偶然在別的文章里看到這個功能&#xff0c;突然覺得正好。 CeleryWorker已經搭好了&#xff0c;但是我一直想在用戶請求時進行額外的處理會比較影響處理時間&#xff0c;用這個正好可以搭配上。 我設想的一個場景&#xff1a; 1 用戶發起請求2 接口中進行關鍵信息…

uboot下讀取ubifs分區的方法

在uboot 的defconfig中增加以下內容&#xff1a; CONFIG_MTDIDS_DEFAULT"nand0nand0" CONFIG_MTDPARTS_DEFAULT"mtdpartsnand0:1M(boot1),1M(boot2),1M(hwinfo),6M(kernel1),6M(kernel2),56M(rootfs1),56M(rootfs2),-(ubi2)" CONFIG_CMD_UBIy 其中&#x…

圖+文+語音一體化:多模態合成數據集構建的實戰與方法論

目錄 圖文語音一體化&#xff1a;多模態合成數據集構建的實戰與方法論 一、多模態合成數據的核心價值 二、系統架構概覽 三、核心模塊與實現建議 ? 1. 文→圖&#xff1a;圖像合成&#xff08;Text-to-Image&#xff09; ? 2. 圖→文&#xff1a;自動描述&#xff08;I…

linux驅動之poll

驅動中 poll 實現 在用戶空間實現事件操作的一個主要實現是調用 select/poll/epoll 函數。那么在驅動中怎么來實現 poll 的底層呢&#xff1f; 其實在內核的 struct file_operations 結構體中有一個 poll 成員&#xff0c;其就是底層實現的接口函數。 驅動中 poll 函數實現原…

第八篇:系統分析師第三遍——3、4章

目錄 一、目標二、計劃三、完成情況四、意外之喜(最少2點)1.計劃內的明確認知和思想的提升標志2.計劃外的具體事情提升內容和標志 五、總結 一、目標 通過參加考試&#xff0c;訓練學習能力&#xff0c;而非單純以拿證為目的。 1.在復習過程中&#xff0c;訓練快速閱讀能力、掌…

C++17 新特性簡解

C17 新特性簡解 一、核心語言特性 1. 結構化綁定&#xff08;Structured Bindings&#xff09; 用途&#xff1a;解構復合類型&#xff08;如元組、結構體&#xff09;為獨立變量 示例&#xff1a; #include <iostream> #include <tuple>int main() {// 解構 st…

PHP使用pandoc把markdown文件轉為word

文章目錄 首先安裝pandocPHP處理 服務器操作系統是Linux&#xff0c;centos 首先安裝pandoc yum install -y pandoc安裝完成后輸入如下代碼&#xff0c;檢查安裝是否成功 pandoc --versionPHP處理 我把markdown內容存到了數據庫里&#xff0c;所以要從數據庫讀取內容。對內容…

【Python學習筆記】Pandas實現Excel質檢記錄表初審、復核及質檢統計

背景&#xff1a; 我有這樣一個需要審核的飛書題目表&#xff0c;按日期分成多個sheet&#xff0c;有初審——復核——質檢三個環節&#xff0c;這三個環節是不同的同學在作業&#xff0c;并且領到同一個題目的人選是隨機的&#xff0c;也就是說&#xff0c;完成一道題的三個人…

守護進程編程、GDB調試以及外網連接樹莓派

目錄 一、什么是守護進程以及如何創建守護進程1. 什么是守護進程&#xff1f;2. 如何創建守護進程&#xff1f; 二、什么是GDB調試以及如何用GDB命令調試C程序1. 什么是GDB&#xff1f;2. 如何用GDB命令調試C程序&#xff1f; 三、外網訪問樹莓派 一、什么是守護進程以及如何創…

Logisim數字邏輯實訓——計數器設計與應用

4位遞增計數器 六進制計數器 十進制計數器 六十進制計數器 二十四進制計數器 計時器

發現“橫”字手寫有難度,對比兩個“橫”字

我發現手寫體“橫”字“好看”程度&#xff0c;難以比得上印刷體&#xff1a; 兩個從方正簡體啟體來的“橫”字&#xff1a; 哪個更好看&#xff1f;我是傾向于左邊一點。 <div style"transform: rotate(180deg); display: inline-block;"> 左邊是我從方正簡…

ubuntu 向右拖動窗口后消失了、找不到了

這是目前單顯示器的設置&#xff0c;因為實際只有1個顯示器&#xff0c;之前的設置如下圖所示&#xff0c;有2個顯示器&#xff0c;一個主顯示器&#xff0c;一個23寸的顯示器 ubuntu 22.04 系統 今天在操作窗口時&#xff0c;向右一滑&#xff0c;發現這個窗口再也不顯示了、找…

專精特新政策推動,B端UI設計如何賦能中小企業創新發展?

在當前數字化轉型浪潮下&#xff0c;專精特新政策為中小企業提供了強大的支持&#xff0c;助力其在細分領域實現專業化、精細化、特色化和創新化發展。B端UI設計作為提升企業數字化產品用戶體驗和工作效率的重要手段&#xff0c;能夠有效賦能中小企業創新發展。本文將探討專精特…

梯度下降代碼

整體流程 數據預處理:標準化->加一列全為1的偏置項 訓練:梯度下降,將數學公式轉換成代碼 預測 模型代碼 import numpy as np# 標準化函數&#xff1a;對特征做均值-方差標準化 # 返回標準化后的特征、新數據的均值和標準差&#xff0c;用于后續預測def standard(feats…

RAG 實戰|用 StarRocks + DeepSeek 構建智能問答與企業知識庫

文章作者&#xff1a; 石強&#xff0c;鏡舟科技解決方案架構師 趙恒&#xff0c;StarRocks TSC Member &#x1f449; 加入 StarRocks x AI 技術討論社區 https://mp.weixin.qq.com/s/61WKxjHiB-pIwdItbRPnPA RAG 和向量索引簡介 RAG&#xff08;Retrieval-Augmented Gen…

從零開始學A2A一:A2A 協議的高級應用與優化

A2A 協議的高級應用與優化 學習目標 掌握 A2A 高級功能 理解多用戶支持機制掌握長期任務管理方法學習服務性能優化技巧 理解與 MCP 的差異 分析多智能體場景下的優勢掌握不同場景的選擇策略 第一部分&#xff1a;多用戶支持機制 1. 用戶隔離架構 #mermaid-svg-Awx5UVYtqOF…