HZOJ-72:猜拳

2023-10-20 01:20
文章标签 72 猜拳 hzoj

本文主要是介绍HZOJ-72:猜拳,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

题目描述

​ 在一次聚会中,每人拿着一张印有石头、剪刀、布的卡片,每个人具体拿得是哪种卡片不得而知。

​ 现在告诉你某些人之间的胜负关系,并会询问某两个人之间的对战结果,人按照从 11 到 n� 编号。

​ 对于每个询问,请给出正确的回答: Win(胜)、Loss(负)、Tie(平)���(胜)、����(负)、���(平)


输入

第一行输入两个整数 n,m(1≤n≤10000,3≤m≤10000)�,�(1≤�≤10000,3≤�≤10000),分别代表人数和信息数量。

接下来 m� 行,每行三个整 a,b,c(a∈[1,2], 1≤b,c≤n)�,�,�(�∈[1,2], 1≤�,�≤�)

  1. 当 a=1�=1 时,代表新增一条已知信息,表示 b, c�, � 对战中 b� 胜
  2. 当 a=2�=2 时,代表根据以上信息,询问 b,c�,� 对战中 b​�​ 的结果

如果出现某条新增的信息与之前的信息发生冲突,就忽略此条信息。

输出

对于每个 a=2�=2 的操作,输出 Win、Loss、Tie���、����、��� 或 Unknown������� 代表对战双方的结果。


样例输入
6 6
1 1 2
2 1 3
1 2 4
1 4 3
2 1 3
2 4 1
样例输出
Unknown
Tie
Win
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
class WeightedUnionSet {
public :WeightedUnionSet(int n) : fa(n + 1), val(n + 1) {for (int i = 0; i <= n; i++) {fa[i] = i;val[i] = 0;}}int get(int x) {if (fa[x] == x) return x;int root = get(fa[x]);val[x] = (val[x] + val[fa[x]]) % 3;return fa[x] = root;}void merge(int a, int b ,int t) {int aa = get(a), bb = get(b);if (aa == bb) return;fa[aa] = bb;val[aa] = (t - val[a] + val[b] + 3) % 3;return;}vector<int> fa, val;
};
int main() {int n, m;cin >> n >> m;WeightedUnionSet u(n);for (int i = 0, a, b, c; i < m; i++) {cin >> a >> b >> c;if (a == 1) {u.merge(b, c, 2);}else {if (u.get(b) != u.get(c)) {cout << "Unknown" << endl;}else {switch ((u.val[b] - u.val[c] + 3) % 3) {case 0: cout << "Tie" << endl; break;case 1: cout << "Loss" << endl; break;case 2: cout << "Win" << endl; break;}}}}return 0;
}

这篇关于HZOJ-72:猜拳的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/243680

相关文章

[Day 72] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

區塊鏈在跨境支付中的應用 跨境支付一直是全球經濟中極具挑戰的領域。傳統的跨境支付系統通常需要數天時間來處理交易,涉及的中間機構多且手續費昂貴。然而,區塊鏈技術的出現為解決這些問題提供了一條嶄新的途徑。本文將探討區塊鏈在跨境支付中的應用,並通過代碼示例展示如何使用區塊鏈技術來優化跨境支付流程。 1. 區塊鏈在跨境支付中的優勢 區塊鏈技術具有去中心化、透明、高效和安全等特性,使其在跨境支付領域具

Leetcode 72. 编辑距离 动态规划 优化 C++实现

Leetcode 72.编辑距离 问题:给你两个单词 word1 和 word2, 请返回将 word1 转换成 word2 所使用的最少操作数  。 你可以对一个单词进行如下三种操作:插入一个字符,删除一个字符,替换一个字符。 算法1:递归搜索 + 保存计算结果 = 记忆化搜索         创建 memo 数组,并赋初始值为 -1,表示还没有被计算过。         进入 d

Leetcode—72. 编辑距离【中等】

2024每日刷题(158) Leetcode—72. 编辑距离 动态规划算法思想 实现代码 class Solution {public:int minDistance(string word1, string word2) {const int m = word1.length();const int n = word2.length();vector<vector<int>>

LeetCode 热题100-72 每日温度

每日温度 给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。 示例 1: 输入: temperatures = [73,74,75,71,69,72,76,73]输出: [1,1,4,2,1,1,0,0] 示例 2:

代码随想录算法训练营第四十五天 | 115.不同的子序列 ,583. 两个字符串的删除操作, 72. 编辑距离

目录 115.不同的子序列 思路 1.确定dp数组(dp table)以及下标的含义 2.确定递推公式 3.dp数组如何初始化 4.确定遍历顺序 5.举例推导dp数组 方法一: 动态规划 方法二:动态规划-一维数组 583. 两个字符串的删除操作 思路 动态规划一 1.确定dp数组(dp table)以及下标的含义 2.确定递推公式 3.dp数组如何初始化 4.确定

【代码随想录训练营第42期 Day45打卡 - 编辑距离问题 - LeetCode 115.不同的子序列 583. 两个字符串的删除操作 72. 编辑距离

目录 一、编辑距离问题总结 二、题目与题解 题目一:115.不同的子序列 题目链接 题解:动态规划 题目二:583. 两个字符串的删除操作 题目链接 题解1:最长公共子序列变形 题解2:编辑问题模板 题目三:72. 编辑距离 题目链接 题解:动态规划  三、小结 一、编辑距离问题总结 编辑距离问题是动态规划算法的一个重要应用,这类问题以 72. 编辑距离

二刷代码随想录训练营Day 45|力扣115.不同的子序列、583. 两个字符串的删除操作、72. 编辑距离

1.不同的子序列 代码随想录 (programmercarl.com) 视频:动态规划之子序列,为了编辑距离做铺垫 | LeetCode:115.不同的子序列_哔哩哔哩_bilibili 代码: class Solution {public:int numDistinct(string s, string t) {vector<vector<uint64_t>> dp(s.size(

代码随想录算法训练营四十五天|115.不同的子序列、583.两个字符串的删除操作、72.编辑距离

题目链接:115. 不同的子序列 - 力扣(LeetCode) class Solution(object):def numDistinct(self, s, t):""":type s: str:type t: str:rtype: int"""dp = [[0] * (len(t) + 1) for _ in range(len(s) + 1)]for i in range(len(s) +

Leetcode:72 Best Time to Buy and Sell Stock

Say you have an array for which the ith element is the price of a given stock on day i. If you were only permitted to complete at most one transaction (ie, buy one and sell one share of the stock),

Leetcode面试经典150题-72.编辑距离

解法都在代码里,不懂就留言或者私信 动态规划最经典题之一,如果写不出来,动态规划好好再学学 class Solution {/**这个题是动态规划最经典的题,另一个最经典的是背包问题 */public int minDistance(String word1, String word2) {/**如果一个为0,取另外一个的长度就可以了 */if(word1.length() == 0 || w