主頁 > 前端設計 > codeforces1426 E. Rock, Paper, Scissors(思維 || 最小費用最大流)

codeforces1426 E. Rock, Paper, Scissors(思維 || 最小費用最大流)

2020-10-02 03:00:19 前端設計

E. Rock, Paper, Scissors

time limit per test

1 second

memory limit per test

256 megabytes

input

standard input

output

standard output

Alice and Bob have decided to play the game "Rock, Paper, Scissors".

The game consists of several rounds, each round is independent of each other. In each round, both players show one of the following things at the same time: rock, paper or scissors. If both players showed the same things then the round outcome is a draw. Otherwise, the following rules applied:

  • if one player showed rock and the other one showed scissors, then the player who showed rock is considered the winner and the other one is considered the loser;
  • if one player showed scissors and the other one showed paper, then the player who showed scissors is considered the winner and the other one is considered the loser;
  • if one player showed paper and the other one showed rock, then the player who showed paper is considered the winner and the other one is considered the loser.

Alice and Bob decided to play exactly nn rounds of the game described above. Alice decided to show rock a1a1 times, show scissors a2a2 times and show paper a3a3 times. Bob decided to show rock b1b1 times, show scissors b2b2 times and show paper b3b3 times. Though, both Alice and Bob did not choose the sequence in which they show things. It is guaranteed that a1+a2+a3=na1+a2+a3=n and b1+b2+b3=nb1+b2+b3=n.

Your task is to find two numbers:

  1. the minimum number of round Alice can win;
  2. the maximum number of rounds Alice can win.

Input

The first line of the input contains one integer nn (1≤n≤1091≤n≤109) — the number of rounds.

The second line of the input contains three integers a1,a2,a3a1,a2,a3 (0≤ai≤n0≤ai≤n) — the number of times Alice will show rock, scissors and paper, respectively. It is guaranteed that a1+a2+a3=na1+a2+a3=n.

The third line of the input contains three integers b1,b2,b3b1,b2,b3 (0≤bj≤n0≤bj≤n) — the number of times Bob will show rock, scissors and paper, respectively. It is guaranteed that b1+b2+b3=nb1+b2+b3=n.

Output

Print two integers: the minimum and the maximum number of rounds Alice can win.

Examples

input

2
0 1 1
1 1 0

output

0 1

input

15
5 5 5
5 5 5

output

0 15

input

3
0 0 3
3 0 0

output

3 3

input

686
479 178 29
11 145 530

output

22 334

input

319
10 53 256
182 103 34

output

119 226

Note

In the first example, Alice will not win any rounds if she shows scissors and then paper and Bob shows rock and then scissors. In the best outcome, Alice will win one round if she shows paper and then scissors, and Bob shows rock and then scissors.

In the second example, Alice will not win any rounds if Bob shows the same things as Alice each round.

In the third example, Alice always shows paper and Bob always shows rock so Alice will win all three rounds anyway.

題意:

alice和bob玩剪刀石頭布,已知alice出了a1個石頭、a2個剪刀、a3個步,bob出了b1個石頭、b2個剪刀、b3個布,問alice最少贏了多少次,最多贏了多少次,

思路:

1、最多贏多少次

讓alice盡量贏就可以了 maxx = min(a1, b2) + min(a2, b3) + min(a3, b1);

2、最少贏多少次

考慮讓alice盡量輸或平,也就是讓a1和b1、b3更多地抵消掉,a2和b2、b1更多地抵消掉,a3和b3、b2更多地抵消掉,抵消后,最優的最終狀態肯定是(全為0)或者(alice剩下一種且bob剩下一種),全為0就不用說了,剩下的情況肯定都是alice贏(因為抵消的都是對贏沒有貢獻的,無法抵消肯定是有貢獻,也就是alice贏),

還有一個小問題,alice如果有剩余一定是一種嗎,答案是肯定的,因為如果alice剩下了兩種:a2個剪刀和a3個布,bob剩下了一種:b1個石頭,(a2 + a3 == b1就不用解釋了8)此時還可以讓alice的剪刀和石頭相抵消,也就是某人剩下兩種時根本不是最終狀態,還可以繼續抵消,因此有剩余情況下的最終狀態肯定是每人一種,

下面來討論一下抵消后alice有剩余的情況:

(1)如果剩下a1,那對應剩下的就是b2,a1 == b2,

整個程序讓b2盡量消失,所以a1、b2的剩余量均為 b2 - a2 - a3,(這里也可以考慮成讓a1盡量地消失,a1、b2的剩余量為a1 - b1 - b3)

(2)如果剩下a2,那對應剩下的就是b3,a2 == b3,

整個程序讓b3盡量消失,所以a2、b3的剩余量均為 b3 - a1 - a3,(這里也可以考慮成讓a2盡量地消失,a2、b3的剩余量為a2 - b1 - b2)

(3)如果剩下a3,那對應剩下的就是b1,a3 == b1,

整個程序讓b1盡量消失,所以a3、b1的剩余量均為 b1 - a1 - a2,(這里也可以考慮成讓a3盡量地消失,a3、b1的剩余量為a3 - b2 - b3)

現在來看一下這三個數(b2 - a2 - a3)、(b3 - a1 - a3)、(b1 - a1 - a2)這三個數中最多只有一個正數,證明如下:

假設 b2 - a2 - a3 > 0,即 b2 > a2 + a3

因為 b1 + b2 + b3 == a1 + a2 + a3 == n

所以 b1 + b3 < a1

所以 b1 < a1 + a2 且 b3 < a1 + a3

所以上面三個數中最多只有一個正數,

所以最終的答案就是從(b2 - a2 - a3)、(b3 - a1 - a3)、(b1 - a1 - a2)中選一個最大值就可以了,

如果上面考慮讓a1、a2、a3盡量地消失就是從(a1 - b1 - b3)、(a2 - b1 - b2)、(a3 - b2 - b3)中選一個最大值,答案是一樣的,因為alice和bob剩下的數肯定相同,

碼 字 好 累 啊

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int inf = 0x3f3f3f3f;
const int N = 1e4 + 10;
const int M = 1e5 + 10;

int main() {
    int n, a[4], b[4];
    scanf("%d", &n);
    for(int i = 1; i <= 3; ++i) scanf("%d", &a[i]);
    for(int i = 1; i <= 3; ++i) scanf("%d", &b[i]);
    ///surprise  max居然可以加大括號
    int minn = max({0, a[1] - b[1] - b[3], a[2] - b[2] - b[1], a[3] - b[3] - b[2]});
    int maxx = min(a[1], b[2]) + min(a[2], b[3]) + min(a[3], b[1]);
    printf("%d %d\n", minn, maxx);
	return 0;
}

最小費用最大流:

超級源點向alice的石頭、剪刀、布連邊,流量分別為a1、a2、a3,費用都為0

bob的石頭、剪刀、布連邊,流量分別為b1、b2、b3,費用都是0

alice的三種決策向bob的三種決策連邊,流量都為inf,只有alice贏時費用為1(貢獻一個贏)

套板子就完了

#include <iostream>
#include <cstdio>
#include <cmath>
#include <vector>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
typedef long long ll;
#define P pair<int,int>
const int inf = 0x3f3f3f3f;
const int N = 1e4 + 10;
const int M = 1e5 + 10;

struct node {
    int x, y;
};
vector<node>peo, house;

struct Edge {
	int to, cap, cost, rev;
};

int n, m, s, t;
int u, v, c, w;
int maxFlow, minCost;

vector<Edge> G[N];
int h[N];   ///頂點的勢
int dist[N], prevv[N], preve[N]; ///dist最短距離 prevv最短路中的父節點 preve最短路中的父邊

void init() {
    maxFlow = 0;
    minCost = 0;
    for(int i = 0; i < N; ++i)
        G[i].clear();
}

void addedge(int from, int to, int cap, int cost) {
	Edge temp1 = { to, cap, cost, (int)G[to].size() };
	Edge temp2 = { from, 0, -cost, (int)G[from].size() - 1 };
	G[from].push_back(temp1);
	G[to].push_back(temp2);
}

void MCMF(int s, int t, int f, int n) {    //n是總結點數
	fill(h + 1, h + 1 + n, 0);
	while (f > 0) {
		priority_queue<P, vector<P>, greater<P> > D;
		memset(dist, inf, sizeof(dist));
		dist[s] = 0; D.push(P(0, s));
		while (!D.empty()) {
			P now = D.top(); D.pop();
			if (dist[now.second] < now.first) continue;
			int v = now.second;
			for (int i = 0; i<(int)G[v].size(); ++i) {
				Edge &e = G[v][i];
				if (e.cap > 0 && dist[e.to] > dist[v] + e.cost + h[v] - h[e.to]) {
					dist[e.to] = dist[v] + e.cost + h[v] - h[e.to];
					prevv[e.to] = v;
					preve[e.to] = i;
					D.push(P(dist[e.to], e.to));
				}
			}
		}
		if (dist[t] == inf) break;
		for (int i = 1; i <= n; ++i) h[i] += dist[i];
		int d = f;
		for (int v = t; v != s; v = prevv[v])
			d = min(d, G[prevv[v]][preve[v]].cap);
		f -= d; maxFlow += d;
		minCost += d * h[t];
		for (int v = t; v != s; v = prevv[v]) {
			Edge &e = G[prevv[v]][preve[v]];
			e.cap -= d;
			G[v][e.rev].cap += d;
		}
	}
}

int main() {
    int cnt, a[4], b[4];
    while(~scanf("%d", &cnt)) {
        init();
        n = 8, s = 0, t = 7;
        for(int i = 1; i <= 3; ++i) {
            scanf("%d", &a[i]);
            addedge(s, i, a[i], 0);
        }
        for(int i = 1; i <= 3; ++i) {
            scanf("%d", &b[i]);
            addedge(i + 3, t, b[i], 0);
        }
        int maxx = min(a[1], b[2]) + min(a[2], b[3]) + min(a[3], b[1]);
        for(int i = 1; i <= 3; ++i) {
            for(int j = 1; j <= 3; ++j) {
                int cst = 0;
                if(i == 1 && j == 2) cst = 1;
                if(i == 2 && j == 3) cst = 1;
                if(i == 3 && j == 1) cst = 1;
                addedge(i, j + 3, inf, cst);
            }
        }
        MCMF(s, t, inf, n + m + 2);
        printf("%d %d\n", minCost, maxx);
    }
	return 0;
}
/*
2
0 1 1
1 1 0
15
5 5 5
5 5 5
3
0 0 3
3 0 0
686
479 178 29
11 145 530
319
10 53 256
182 103 34
94317
66277 24448 3592
3499 24653 66165
*/

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/147056.html

標籤:其他

上一篇:國仁老貓:“視頻號”最新最全變現引流方式大全;值得收藏【下】

下一篇:Python智力問答小游戲

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more