题目网址

https://vijos.org/d/Randle/p/5a0011e1d3d8a10a532d6d71

题目描述

在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数。你的邪王真眼可以看到所有牌朝上的一面和朝下的一面写的数字。现在你需要将一些牌翻过来,使得所有牌朝上的一面中,至少有一半(≥n/2)的数字是一样的。请你求出最少需要翻几张牌,或者判断无解。注意:在翻牌的时候,你不能把牌扔掉,不能偷偷把别的牌放进来,也不能用笔涂改牌上面的数字。

输入格式

第一行包含一个整数n,表示牌的数量;接下来n行,每行两个非负整数ai, bi,表示每张牌上写的两个数字,ai对应朝上的一面,bi对应朝下的一面。

输出格式

如果有解,则输出一个整数,表示最少的翻牌次数,否则输出Impossible。

样例

样例输入1

3
1 2
2 1
3 4

样例输出1

1

样例输入2

3
1 2
3 4
5 6

样例输出2

Impossible

样例说明

样例解释1

把第一张牌翻过来,那么就有两个2一个3朝上了,2的数量超过了半数。

样例解释2

所有数字都只有一个,因此相同的数字数超过半数是不可能的。

数据范围

ai,bi<=10^9,n<=3*10^5
对所有数据,有n>0,ai, bi≥0。

题解

本题扫一眼会觉得很简单,但是再扫一眼,就会发现,真的是很烦。

首先,本题很难枚举翻哪一张牌,因为可以同时翻好几张牌。那么,本题的难点就是在于问题的转化。

不好枚举翻哪一张牌,那么我们就枚举哪一种牌可以翻。

如样例1,出现次数最多的是2,那么我们就可以枚举出翻含有2的牌的次数。

但是本题还有一个细节:出现次数最多的数字一定只需要翻最少次数吗?当然不一定,这种情况一定要考虑。

另外,本题还用到了离散化,离散化可以用map来实现

再把思路整理一遍

1.读入n

2.进行n次操作,每次读入ai和bi,利用map,将ai和bi分开进行离散化处理

注意:如果ai和bi的值相等,那么只能存储一次,以为这种牌无论翻不翻都一样

3.读入ai和bi的同时,将他们存放在一个数组中,并在读入结束后对该数组(用A[]表示)进行排序(理论上该排序没有任何意义,但是加上以后确实能快一点)

4.从1开始枚举A[]中左右的元素,对其出现次数进行判断,看能否满足超过一半的条件。如果可以,计算出它需要的最少次数,并对所有可行方案求最小值

代码

 #include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <bits/stdc++.h>
using namespace std; const int N=; map<int,int> M0,M1;
int A[*N];
int n,m,a[N],b[N],ans=N; void init()
{
scanf("%d", &n);
for (int i=; i<=n; i++)
{
scanf("%d %d",&a[i], &b[i]);
if (a[i]==b[i]) M0[a[i]]++;//记录a的次数
else M0[a[i]]++, M1[b[i]]++;
A[++m]=a[i];//将所有出现的数都放在A[]中
A[++m]=b[i];
}
sort(A+,A+m+);
} void work()
{
for (int i=; i<=m; i++)//枚举在最终要翻的牌面数字
{
int x=M0[A[i]],y=M1[A[i]];
if (x+y>=(n+)/)
ans=min(ans,max((n+)/-x,));
}
if (ans==N)printf("Impossible\n");
else printf("%d\n",ans);
return;
} int main()
{
init();
work();
return ;
}

出处:https://www.cnblogs.com/yujustin/

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

温馨提示:尽量使用版本较高的浏览器,并打开极速模式。

Vijos 纸牌的更多相关文章

  1. vijos题解

    Vijos题解 题库地址:https://vijos.org/p P1001 谁拿了最多奖学金 题意:按照指定要求计算奖学金,直接用if判断即可 #include<iostream> us ...

  2. 【BZOJ 1061】【Vijos 1825】【NOI 2008】志愿者招募

    http://www.lydsy.com/JudgeOnline/problem.php?id=1061 https://vijos.org/p/1825 直接上姜爷论文... #include< ...

  3. code vs 1098 均分纸牌(贪心)

    1098 均分纸牌 2002年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解   题目描述 Description 有 N 堆纸牌 ...

  4. C语言-纸牌计算24点小游戏

    C语言实现纸牌计算24点小游戏 利用系统时间设定随机种子生成4个随机数,并对4个数字之间的运算次序以及运算符号进行枚举,从而计算判断是否能得出24,以达到程序目的.程序主要功能已完成,目前还有部分细节 ...

  5. vijos P1915 解方程 加强版

    背景 B酱为NOIP 2014出了一道有趣的题目, 可是在NOIP现场, B酱发现数据规模给错了, 他很伤心, 哭得很可怜..... 为了安慰可怜的B酱, vijos刻意挂出来了真实的题目! 描述 已 ...

  6. vijos P1780 【NOIP2012】 开车旅行

    描述 小\(A\)和小\(B\)决定利用假期外出旅行,他们将想去的城市从\(1\)到\(N\)编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市\(i\)的海拔高度为 ...

  7. 【BZOJ 2541】【Vijos 1366】【CTSC 2000】冰原探险

    http://www.lydsy.com/JudgeOnline/problem.php?id=2541 https://vijos.org/p/1366 loli秘制大爆搜_(:з」∠)_坑了好久啊 ...

  8. 【BZOJ 1065】【Vijos 1826】【NOI 2008】奥运物流

    http://www.lydsy.com/JudgeOnline/problem.php?id=1065 https://vijos.org/p/1826 好难的题啊TWT ∈我这辈子也想不出来系列~ ...

  9. 一起来做webgame,《Javascript蜘蛛纸牌》

    不得不说,做游戏是会上瘾的,这次带来的是win系统上的经典游戏<蜘蛛纸牌>,不能完美,但求一玩 移牌 0 次 Javascript game_蜘蛛纸牌 正在努力加载... // " ...

随机推荐

  1. Angular 5.x 学习笔记(1) - 模板语法

    Angular 5.x Template Syntax Learn Note Angular 5.x 模板语法学习笔记 标签(空格分隔): Angular Note on github.com 上手 ...

  2. java--内存管理的几点小技巧

    今天看一本书,书上提到了内存泄露,后面也提到了内存管理的小技巧,在这里记下来,以免以后忘记. 1.尽量使用直接量.比如:String str = "I can play!";而不是 ...

  3. 作为软件技术人员建立自己的git账户并保存资料的重要性

    日常生活中,当修改并保存了一个文件,所得到的就是此文件的最新版本,假若今后因某一问题需要用到原来文件,可是很多情况下,这种修改是不可逆的.你修改完之后,无法回到你修改前的样子.为了避免这种情况,有的人 ...

  4. 如何通过一个SAPGUI屏幕反查这个屏幕对应的事务码

    假设我通过某种跳转方式打开了下图这个SAPGUI的屏幕,但我想搞清楚用哪一个事务码可以直接到达这个屏幕,而不通过繁琐的点击,应该怎么做? 步骤1,点击Order字段,按F1打开帮助界面, 点上图的图标 ...

  5. Android(java)学习笔记9:JDK5之后的Lock锁的概述和使用

    1. Lock锁的概述: java.util.concurrent.locks,接口Lock 首先Lock是一个接口,Lock实现提供了比使用synchronized方法 和 同步代码块更为广泛的锁定 ...

  6. Python:一些小知识

    小知识点总结 一.Python2与Python3 的区别 1.Python2中可以加括号输出,也可不加输出     Python3中必须加 2.python2 中有xrange(生成器)也有range ...

  7. css relative

    一.relative和absolute相煎关系 relative限制absolute 1.限制left/top/right/bottom定位 如果父元素有relative,只能根据父元素进行定位 2. ...

  8. PHP设计模式——责任链模式

    <?php /** * 责任链模式 * 组织一个对象链处理一个请求,每个处理对象知道自己能处理哪些请求,并把自己不能处理的请求交下一个处理对象 * * 适用场景: * 1.有多个对象可以处理同一 ...

  9. c#加一个后台线程

  10. 用keytool制作证书并在tomcat配置https服务(四)

    用keytool制作证书并在tomcat配置https服务(一) 用keytool制作证书并在tomcat配置https服务(二) 用keytool制作证书并在tomcat配置https服务(三) 上 ...