Topcoder SRM 648 (div.2)

?

第一次做TC全部通過,截圖紀念一下。

終于藍了一次,也是TC上第一次變成藍名,下次就要做Div.1了,希望div1不要掛零。。。_(:зゝ∠)_

?

A. KitayutaMart2

萬年不變的水題。

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<set>
#include<map>
#include<stack>
#include<vector>
#include<queue>
#include<string>
#include<sstream>
#define eps 1e-9
#define ALL(x) x.begin(),x.end()
#define INS(x) inserter(x,x.begin())
#define FOR(i,j,k) for(int i=j;i<=k;i++)
#define MAXN 1005
#define MAXM 40005
#define INF 0x3fffffff
using namespace std;
typedef long long LL;
int i,j,k,n,m,x,y,T,ans,big,cas,num;
bool flag;
class KitayutaMart2
{public:int numBought(int K, int T){m=T/K;m++;ans=0;while (m!=0) {m>>=1;ans++;}return ans-1;}
};
View Code

B. Fragile2

給一個N個點(3<=N<=20)的無向圖,現在不分先后取出其中兩個點,使得強連通分量變多,問最多有多少種取法。

?

因為圖實在太小了,所以枚舉這兩個點即可。用DFS計算連通分支數。

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<set>
#include<map>
#include<stack>
#include<vector>
#include<queue>
#include<string>
#include<sstream>
#define eps 1e-9
#define ALL(x) x.begin(),x.end()
#define INS(x) inserter(x,x.begin())
#define FOR(i,j,k) for(int i=j;i<=k;i++)
#define MAXN 1005
#define MAXM 40005
#define INF 0x3fffffff
using namespace std;
typedef long long LL;
int i,j,k,n,m,x,y,T,ans,big,cas,num,G[55][55],G2[55][55];
bool flag;
int vis[55];
class Fragile2
{public:void check(int u){int i,j,k;for (i=0;i<n;i++){if (!vis[i] && G2[u][i]){vis[i]=1;check(i);}}}int cc(int a,int b)//計算刪去結點a,b后的連通度 
        {int i,j,k,blk;memset(vis,0,sizeof(vis));for (i=0;i<n;i++)//復制一下地圖 
               {for (j=0;j<n;j++){G2[i][j]=G[i][j]; }}vis[a]=1;vis[b]=1;//刪去結點a,b for (i=0;i<n;i++) {G2[i][a]=0;G2[a][i]=0;G2[b][i]=0;G2[i][b]=0;}blk=0; for (i=0;i<n;i++)//計算強連通分量 
            {if (!vis[i]){blk++;vis[i]=1;check(i); }}return blk;}int countPairs(vector <string> mp){int i,j,k;n=mp.size();for (i=0;i<n;i++)//復制一下地圖到G 
               {for (j=0;j<n;j++){if (mp[i][j]=='N') G[i][j]=0;else G[i][j]=1;}}num=cc(n,n);//計算一下不修改地圖時的強連通分量數 
               ans=0;for (i=0;i<n;i++)//枚舉要刪除的兩個點。 
              {for (j=i+1;j<n;j++){if (num<cc(i,j)) ans++;}}return ans;}
};
View Code

?

C.ABC

字符串長為N(3<=N<=30),并且由大寫字母A,B,C組成,其中存在K(k<=N*(N-1)/2)對數i和j,滿足i<j,s[i]<s[j]。現在給出N,K,試著構造任意一個滿足條件的字符串

?

動態規劃,設dp[a][b][c][s]!=0時為當前字符串由a個字母A,b個字母b,c個字母C組成,并且得分為s成立。而dp[a][b][c][s]=0表示由a個字母A,b個字母b,c個字母C組成的字符串不可能得分為s。

轉移方程

(1) dp[a+1][b][c][s]=dp[a][b][c][s];

(2) dp[a][b+1][c][s+a]=dp[a][b][c][s]

(3) dp[a][b][c+1][s+a+b]=dp[a][b][c][s]

初始狀態為dp[0][0][0][0]=1

因為我們要遞歸輸出,所以設dp[a][b][c][s]=1為由狀態1轉移過來的,dp[a][b][c][s]=2為由狀態2轉移過來的,dp[a][b][c][s]=3為由狀態3轉移過來的

最后遞歸輸出答案即可。

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<set>
#include<map>
#include<stack>
#include<vector>
#include<queue>
#include<string>
#include<sstream>
#define eps 1e-9
#define ALL(x) x.begin(),x.end()
#define INS(x) inserter(x,x.begin())
#define FOR(i,j,k) for(int i=j;i<=k;i++)
#define MAXN 1005
#define MAXM 40005
#define INF 0x3fffffff
using namespace std;
typedef long long LL;
int i,j,k,n,m,x,y,T,big,cas,num;
bool flag;
int dp[35][35][35][440];
string ans;class ABC
{public:void out(int x,int y,int z,int s){if (x<=0&&y<=0&&z<=0&&s<=0) return;if (dp[x][y][z][s]==1) {out(x-1,y,z,s);ans+="A";}elseif (dp[x][y][z][s]==2) {out(x,y-1,z,s-x);ans+="B";}else{out(x,y,z-1,s-x-y);ans+="C";}}string createString(int n, int c){int i,j,k,l;dp[0][0][0][0]=1;for (i=0;i<=n;i++){for (j=0;i+j<=n;j++){for (k=0;i+j+k<=n;k++){for (l=0;l<=c;l++){if (dp[i][j][k][l]){if (i+j+k==n && l==c)//找到答案,輸出 
                                {out(i,j,k,l);//遞歸輸出return ans;}dp[i+1][j][k][l]=1;if (l+i<=c) dp[i][j+1][k][l+i]=2; if (l+i+j<=c) dp[i][j][k+1][l+i+j]=3;}}}}}return "";}
View Code

?

轉載于:https://www.cnblogs.com/zhyfzy/p/4268944.html

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

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

相關文章

Kadane's algorithm學習

Kadane’s algorithm 簡單來說就是用來計算數組中的連續子數組之和最大是多少 vector<int> vec; int temp 0,ans 0; for(int i0;i<vec.size();i){temp max(tempvec[i],vec[i]);ans max(temp,ans); } return ans;循環的第一行就是用來比較當前位置的值和前面數組…

好用的ajax后臺框架

dwz 簡單實用的國產jquery Ui框架 http://www.j-ui.com/#_blank轉載于:https://www.cnblogs.com/userbibi/p/3441382.html

OpenFire源碼學習之十九:在openfire中使用redis插件(上)

Redis插件 介紹 Redis是目前比較流行的NO-SQL&#xff0c;基于K,V的數據庫系統。關于它的相關操作信息&#xff0c;本人這里就不做重復了&#xff0c;相關資料可以看這個網站http://www.redis.io/(官網)、http://www.redis.cn/(中文站)。 這里本人想說的是&#xff0c;拿Redis做…

c++ queue學習

參考資料&#xff1a; cppreference.com 本文代碼&#xff1a; 本文源碼 目錄成員函數1.operator &#xff08;賦值給容器&#xff09;元素訪問2.front &#xff08;訪問第一個元素&#xff09;3.back &#xff08;訪問最后一個元素&#xff09;容量4.empty &#xff08;判斷容…

沒有文件擴展“.js”的腳本引擎問題解決

安裝MinGW的時候提示沒有文件擴展“.js”的腳本引擎。原因&#xff1a;系統安裝Dreamwear、UltraEdit、EditPlus后修改了.js文件的默認打開方式。當想直接執行js腳本時就會出現此錯誤。解決辦法&#xff1a;打開注冊表編輯器&#xff0c;定位[HKEY_CLASSES_ROOT.js]這一項&…

160 - 54 eKH

環境&#xff1a;windows xp 工具&#xff1a; 1、OllyDBG 2、IDA 3、exeinfo 查殼發現是程序無殼且用Delphi語言編寫 可以通過搜索字符串的方式定位關鍵函數地址 這里定位到是 00427B44ReadInput(a2, &v17); // 讀取輸入的usernameif ( StrL…

點賺接口(第二版)

1.查看是否有新消息 url&#xff1a;/get/message/status?user_id{user_id} method&#xff1a;get response&#xff1a; {"code": "ok","msg": "","data": 0 //新消息數目 } 2.獲取消息列表 url&#xff1a;/get/messa…

Java基礎之線程——使用Runnable接口(JumbleNames)

控制臺程序。 除了定義Thread新的子類外&#xff0c;還可以在類中實現Runnable接口。您會發現這比從Thread類派生子類更方便&#xff0c;因為在實現Runnable接口時可以從不是Thread的類派生子類&#xff0c;并且仍然表示線程。Java只允許有單個基類&#xff0c;如果類派生于Thr…

cpri帶寬不足的解決方法_白皮書:FPGA賦能下一代通信和網絡解決方案(第四部分)...

對PCIe Gen 5的支持除了以太網和存儲控制器&#xff0c;Speedster7t FPGA上提供的對PCIe Gen 5的支持還能夠與主機處理器緊密集成&#xff0c;以支持諸如sidecar智能網卡(SmartNIC)設計等高性能加速器應用。PCI Gen 5控制器使其能夠讀取和寫入存儲在FPGA內存層級結構中的數據&a…

laravel里面使用event

模式&#xff1a;大概是通過一個自定義的event&#xff0c;一個handler&#xff0c;還有一個binder&#xff0c;然后用來簡化通知模型 生成自定義的event ./artisan make:event MyEvent 生成自定義的handler ./artisan handler:event MyEventHandler --eventMyEvent 然后在Even…

C語言的條件編譯#if, #elif, #else, #endif、#ifdef, #ifndef

有些程序在調試、兼容性、平臺移植等情況下可能想要通過簡單地設置一些參數就生成一個不同的軟件&#xff0c;這當然可以通過變量設置&#xff0c;把所有可能用到的代碼都寫進去&#xff0c;在初始化時配置&#xff0c;但在不同的情況下可能只用到一部分代碼&#xff0c;就沒必…

山體等高線怎么看_每日一題 | 此處向斜山,你看出來了嗎?

每日一題 | 此處向斜山&#xff0c;你看出來了嗎&#xff1f;(2018江蘇高考)如圖為某區域地質簡圖。該區沉積地層有Q、P、C、D、S2、S1&#xff0c;其年代依次變老。讀圖回答1&#xff5e;2題。1&#xff0e;從甲地到乙地的地形地質剖面示意圖是(  )2&#xff0e;為揭示深部地…

cmake The source directory xxxx does not appear to contain CMakeLists.txt

執行 cmake . 的時候報錯&#xff1a; The source directory “xxxx” does not appear to contain CMakeLists.txt 簡單來說就是當前文件夾里面沒有 CMakeLists.txt

SSH出錯--hibernate--org.hibernate.hql.ast.QuerySyntaxException: User is not mapped [from User]

String queryString "from user where u.userName ? and u.userPassword ?"; ----------------------------------------------------------- 改為&#xff1a; String queryString "from User where u.userName ? and u.userPassword ?"; 我估…

Linux下的tar壓縮解壓縮命令詳解

tar -c: 建立壓縮檔案-x&#xff1a;解壓-t&#xff1a;查看內容-r&#xff1a;向壓縮歸檔文件末尾追加文件-u&#xff1a;更新原壓縮包中的文件 這五個是獨立的命令&#xff0c;壓縮解壓都要用到其中一個&#xff0c;可以和別的命令連用但只能用其中一個。下面的參數是根據需要…

java和c++的區別大嗎_大空間消防水炮ZDMS0.8/30S坐裝和吊裝有區別嗎?

大空間消防水炮現在是高大建筑的消防必備的設備之一&#xff0c;其型號按照流量可分為4種&#xff0c;ZDMS0.6/5S&#xff0c;ZDMS0.6/10S&#xff0c;SZDMS0.8/20S&#xff0c;ZDMS0.8/30S。在這中間使用較多的是5L和30L的&#xff0c;5L的消防水炮都是吊裝&#xff0c;但是30…

Windows Hook(1)加載DLL

DLL代碼 #include <Windows.h> BOOL APIENTRY DllMain( HMODULE hModule,DWORD ul_reason_for_call,LPVOID lpReserved) {switch (ul_reason_for_call){case DLL_PROCESS_ATTACH:MessageBox(NULL, L"dllHook", L"Hook", MB_OK);break;case DLL_THR…

WPF Delegate委托整理

那啥&#xff0c;是從這里整理出來的&#xff0c;感謝Rising_Sun&#xff0c;整理的過于簡單&#xff0c;看不明白的戳這里 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Windows; using System.Windows.Controls; us…

silverligh的數據訪問

對于在Silverlight中訪問數據&#xff0c;初學者的誤解之一就是他們在Silverlight中尋找ADO.NET類庫。別找了&#xff0c;找不到的。記住&#xff0c;Silverlight是部署在互聯網上的客端技術&#xff0c;你不能要求一個瀏覽器插件去直接訪問你的數據庫……除非你想把數據庫直接…

cacheinterceptor第二次訪問沒被調用_訪問者設計模式在OSG中的應用

為什么要談談訪問者設計模式呢&#xff1f;因為OSG整個引擎就是用訪問者設計模式建立起來的&#xff0c;不論是遍歷節點圖&#xff0c;還是做各種實用的功能&#xff0c;都需要大量的用到訪問者設計模式。先談談訪問者設計模式的定義。1&#xff1a;什么是訪問者模式訪問者模式…