POJ 3683 Priest John's Busiest Day(2-ST)

題目鏈接:http://poj.org/problem?id=3683

題意:有n個婚禮要舉行,但是只有一個牧師。第i個婚禮使用牧師的時間長為leni,可以在開始時或結束時使用。問能否使得n個婚禮均舉行?

思路:對于婚禮i,i*2-1表示在開始使用牧師,i*2表示在結束使用牧師。枚舉每一對不同的i和j:

(1)如果i*2-1和j*2-1沖突。連接i*2-1 ?j*2

(2)如果i*2-1和j*2沖突,連接i*2-1 j*2-1

(3)如果i*2和j*2-1沖突,連接i*2 j*2

(4)如果i*2和j*2沖突,連接i*2 j*2-1

?

 #include <stdio.h>#include <string.h>#include <stack>#define min(x,y) ((x)<(y)?(x):(y))using namespace std;struct node{int v,next;};const int MAX=4005;const int MAXE=5000005;node edges[MAXE];int head[MAX],e;int dfn[MAX],low[MAX],visit[MAX],color[MAX],col[MAX];int n,index,cnt;stack<int> S;int deg[MAX],ans[MAX],p[MAX];int head1[MAX],e1;node edges1[MAXE];void Add(int u,int v){edges[e].v=v;edges[e].next=head[u];head[u]=e++;}void Add1(int u,int v){edges1[e1].v=v;edges1[e1].next=head1[u];head1[u]=e1++;}void Tarjan(int u){int i,v;low[u]=dfn[u]=++index;S.push(u);visit[u]=1;for(i=head[u];i!=-1;i=edges[i].next){v=edges[i].v;if(!dfn[v]){Tarjan(v);low[u]=min(low[u],low[v]);}else if(visit[v]) low[u]=min(low[u],dfn[v]);}if(dfn[u]==low[u]){cnt++;do{v=S.top();S.pop();visit[v]=0;color[v]=cnt;}while(u!=v);}}void init(){memset(deg,0,sizeof(deg));memset(head1,-1,sizeof(head1));e1=0;int i,u,v,x,y;for(u=1;u<=2*n;u++){for(i=head[u];i!=-1;i=edges[i].next){v=edges[i].v;if(color[v]!=color[u]){x=color[v];y=color[u];Add1(x,y);deg[y]++;}}}while(!S.empty()) S.pop();for(i=1;i<=cnt;i++) if(!deg[i]) S.push(i);memset(p,0,sizeof(p));while(!S.empty()){u=S.top();S.pop();if(!p[u]) p[u]=1,p[col[u]]=-1;for(i=head1[u];i!=-1;i=edges1[i].next){v=edges1[i].v;if(--deg[v]==0) S.push(v);}}memset(ans,0,sizeof(ans));for(i=1;i<=n;i++){if(p[color[i*2-1]]==1) ans[i]=1;}}int TWO_ST(){int i;memset(dfn,0,sizeof(dfn));memset(visit,0,sizeof(visit));index=cnt=0;while(!S.empty()) S.pop();for(i=1;i<=2*n;i++) if(!dfn[i]) Tarjan(i);for(i=1;i<=n;i++){if(color[i*2-1]==color[i*2]) return 0;col[color[i*2-1]]=color[i*2];col[color[i*2]]=color[i*2-1];}init();return 1;}struct Node{int s,e,len;};Node a[MAX];void deal(){if(!TWO_ST()){puts("NO");return;}puts("YES");int i,x,y;for(i=1;i<=n;i++){ans[i]?(x=a[i].s,y=a[i].s+a[i].len):(x=a[i].e-a[i].len,y=a[i].e);printf("%02d:%02d %02d:%02d\n",x/60,x%60,y/60,y%60);}}int OK(int s1,int len1,int s2,int len2){return s1<s2+len2&&s2<s1+len1;}int main(){while(scanf("%d",&n)!=-1){int i,j,h1,m1,h2,m2;for(i=1;i<=n;i++){scanf("%d:%d %d:%d %d",&h1,&m1,&h2,&m2,&a[i].len);a[i].s=h1*60+m1;a[i].e=h2*60+m2;}memset(head,-1,sizeof(head));e=0;int u,v;for(i=1;i<=n;i++) for(j=1;j<=n;j++) if(i!=j){if(OK(a[i].s,a[i].len,a[j].s,a[j].len)) Add(i*2-1,j*2);if(OK(a[i].s,a[i].len,a[j].e-a[j].len,a[j].len)) Add(i*2-1,j*2-1);if(OK(a[i].e-a[i].len,a[i].len,a[j].s,a[j].len)) Add(i*2,j*2);if(OK(a[i].e-a[i].len,a[i].len,a[j].e-a[j].len,a[j].len)) Add(i*2,j*2-1);}deal();}return 0;}

?

  

?

?

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

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

相關文章

12個git實戰建議和技巧

摘要&#xff1a;git無疑是現在最熱門的版本控制工具&#xff0c;而且正在進一步侵占SVN以及CVS的市場。本文作者從國外技術問答社區Stack Overflow整理的12個很實用的git使用技巧和建議&#xff0c;希望對你有幫助。 1.使用“git diff”來折疊多行 用git diff經常會出現很多內…

python讀寫json和txt

讀寫json #數據保存如json文件 import json jsObj json.dumps(code_sec) fileObject open(jsonFile.json, w) fileObject.write(jsObj) fileObject.close() #讀取json文件 # 將類文件對象中的JSON字符串直接轉換成 Python 字典 with open(jsonFile.json, r, encoding…

Java 12 將于3月19日發布,8 個最終 JEP 一覽

開發四年只會寫業務代碼&#xff0c;分布式高并發都不會還做程序員&#xff1f; JDK 12 已于2018年12月進入 Rampdown Phase One 階段&#xff0c;這意味著該版本所有新的功能特性被凍結&#xff0c;不會再加入更多的 JEP 。該階段將持續一個月&#xff0c;主要修復 P1-P3 級…

股票期貨數據的resample處理

? import pandas as pd stock_day pd.read_csv("stock_day.csv") stock_day stock_day.sort_index() # 對每日交易數據進行重采樣 &#xff08;頻率轉換&#xff09; stock_day.index# 1、必須將時間索引類型轉換成Pandas默認的類型 stock_day.index pd.to_datet…

ArcEngine調用FeatureToLine工具傳參問題

FeatureToLine工具的in_features參數不能為內存圖層&#xff0c;否則會報內存錯誤&#xff0c;正確的寫法如下&#xff1a; FeatureToLine ftrToLine new FeatureToLine(); ftrToLine.in_features cpj.TempWs.PathName "\OriginDataset\" currentFc.Key; ftrToLi…

程序員如何做出“不難看”的設計

摘要&#xff1a;程序員在寫代碼的時候往往只注重功能的實現和性能的提升&#xff0c;忽視了外觀和易用性&#xff0c;其實很多時候只要注意一些基本的規則&#xff0c;就可以大幅度提高產品的觀感。 經常看到程序員展示自己做的東西&#xff0c;有一些是創業項目&#xff0c;有…

微服務實戰(二):使用API Gateway

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 當你決定將應用作為一組微服務時&#xff0c;需要決定應用客戶端如何與微服務交互。在單體式程序中&#xff0c;通常只有一組冗余的或者…

sql數據庫挖坑

sql數據庫存入數據時&#xff0c;因為列 名不允許有括號&#xff0c;無法識別&#xff0c;需要對括號進行剔除 df df.rename(columnslambda x: x.replace("(","").replace(),))

力扣——頂端迭代器

給定一個迭代器類的接口&#xff0c;接口包含兩個方法&#xff1a; next() 和 hasNext()。設計并實現一個支持 peek() 操作的頂端迭代器 -- 其本質就是把原本應由 next() 方法返回的元素 peek() 出來。 示例: 假設迭代器被初始化為列表 [1,2,3]。調用 next() 返回 1&#xff0c…

五步讓你成為專家級程序員

摘要&#xff1a;Mark Lassoff是一位高級技術培訓師&#xff0c;從事培訓工作已有10余年。他培訓的客戶包括美國國防部、Lockheed Martin等。在多年的培訓生涯中&#xff0c;他總結了一些如何快速學習一門語言的技巧&#xff0c;這些技巧非常簡單&#xff0c;但是卻讓人受益匪淺…

Ionic混合移動app框架學習

第一章 緒論創建移動app有三種安卓原生App&#xff0c;使用java語言&#xff0c;目前推薦kotlin語言&#xff0c;開發工具Android studioIOS原生App&#xff0c;使用Objective-C或者Swift語言&#xff0c;開發工具Xcode混合移動App&#xff0c;使用web通用語言&#xff08;HTML…

IPC 中 LPC、RPC 的區別和聯系

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 進程間通信&#xff08;IPC&#xff0c;Inter-Process Communication&#xff09;&#xff0c;指至少兩個進程或線程間傳送數據或信號的…

Laravel 使用 Aliyun OSS 云存儲

對象存儲 ( Object Storage Service, 簡稱 OSS ) OSS 相信大家都聽過, 它是阿里云對外提供的海量, 安全和高可靠的云存儲服務. 大家可以把自己網站的資源存上面加快自己網站速度, aliyun 官網也有文檔不過對于新手來說有點難, 那么這里我給大家推薦一個組件和組件的使用. johnl…

python多級索引修改

創建多級索引 cols pd.MultiIndex.from_tuples([("a","b"), ("a","c")]) pd.DataFrame([[1,2], [3,4]], columnscols) abc012134 df.columns df.columns.droplevel() df bc012134

在線學習新編程 技巧全攻略

摘要&#xff1a;有句俗語叫&#xff1a;“技多不壓身”&#xff0c;如果你有時間和興趣&#xff0c;不妨多了解和掌握編程技能&#xff0c;或許隨時可能有用。本文為你收集了一些編程技巧&#xff0c;讓你輕松學編程。 有句俗語叫&#xff1a;“技多不壓身”&#xff0c;如果你…

第 3 章 鏡像 - 018 - 鏡像命名的最佳實踐

為鏡像命名 創建鏡像時 docker build 命令時已經為鏡像取了個名字&#xff0c;例如&#xff1a; docker build -t ubuntu-with-vi 這里的 ubuntu-with-vi 就是鏡像的名字。通過 dock images 可以查看鏡像的信息。 1 rootubuntu:~# docker images ubuntu-with-vi 2 REPOSITORY …

Jmeter邏輯控制器-ForEach Controller

ForEach Controller 介紹 ForEach Contoller 即循環控制器&#xff0c;顧名思義是定義一個規則。主要有以下一個參數&#xff1a;名稱&#xff1a;隨便填寫注釋&#xff1a;隨便填寫輸入變量前綴&#xff1a;可以在“用戶自定義變量”中定義一組變量。循環控制器可以從中獲取到…

微服務實戰(三):深入微服務架構的進程間通信

見&#xff1a;http://www.dockone.io/article/549簡介 在單體式應用中&#xff0c;各個模塊之間的調用是通過編程語言級別的方法或者函數來實現的。但是一個基于微服務的分布式應用是運行在多臺機器上的。一般來說&#xff0c;每個服務實例都是一個進程。因此&#xff0c;如下…

python輸出與刪除某行或某列

python輸出字符&#xff0c;主要為結合變量形成新的變量名 year 2016 event Referendum fResults of the {year} {event}Results of the 2016 Referendum yes_votes 42_572_654 no_votes 43_132_495 percentage yes_votes / (yes_votes no_votes) {:-9} YES votes {:2…

為什么應該用模塊取代C/C++中的頭文件?

摘要&#xff1a;本文整理自Apple C工程師Doug Gregor的演講Slide&#xff0c;他表示希望使用模塊&#xff08;Module&#xff09;這一概念替代C/C中的頭文件&#xff0c;現已被C標準化委員會任命為Module研究組的主席&#xff0c;研究該提議的可能性。考慮到Apple的開源項目LL…