【codeforces 534D】Handshakes

【题目链接】:http://codeforces.com/contest/534/problem/D

【题意】

n个人依次进入一个房间;
进进来的人会和房间里面没有组队的人握一次手;
(这里的握手只计算主动握手的那个人的握手次数);
(任意时刻,任意3个人都能组队);
给出每个人的握手信息;
问你n个人进入房间的顺序是怎么样的。

【题解】

一开始房间里面一个人都没有;
这个时候,看看哪个人握手的次数为0;
->
房间里面变成了两个人,然后看看哪个人的握手次数为2
->
房间里面变成了三个人,然后看看哪个人的握手次数为3
->

然后如果遇到没有和房间里面的人数相符合的握手数;
就尝试去掉3个人(这3个人就相当于是去掉了);
然后再看看有没有和房间里面人数相对应的握手次数;
以此类推;
如果已经没办法减少人数了,且还有人没有进入房间,且没有人和房间里面的人数的握手数相对应;
则输出无解信息.

【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%lld",&x)
#define ref(x) scanf("%lf",&x)typedef pair<int, int> pii;
typedef pair<LL, LL> pll;const int dx[9] = { 0,1,-1,0,0,-1,-1,1,1 };
const int dy[9] = { 0,0,0,-1,1,-1,1,-1,1 };
const double pi = acos(-1.0);
const int N = 2e5+100;int n;
vector <int> v[N],ans;
int bo[N],num,tot;int main()
{//freopen("F:\\rush.txt", "r", stdin);rei(n);rep1(i, 1, n){int x;rei(x);bo[x]++;v[x].push_back(i);}while (tot < n){if (!bo[num]){while (num >= 3){num -= 3;if (bo[num]) break;}if (!bo[num])return puts("Impossible"),0;}bo[num]--;ans.push_back(v[num].back());v[num].pop_back();num++, tot++;}puts("Possible");rep1(i, 0, tot - 1){printf("%d", ans[i]);if (i == tot - 1)puts("");elseputchar(' ');}//printf("\n%.2lf sec \n", (double)clock() / CLOCKS_PER_SEC);return 0;
}

转载于:https://www.cnblogs.com/AWCXV/p/7626510.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/415713.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

lab 常用配置参数 代码片段

1、--leaks 启用内存泄漏检测&#xff0c;并在检测到时向您发出警告 2、代码片段 experiment(getting started with hapi testing,, () > {// 这种写法会跳过测试test(lab considers this test as TOOD and skips it)// 这种写法不会跳过测试test(always succeeding :), (…

android 底部表格布局TableLayout

添加依赖compile com.flyco.tablayout:FlycoTabLayout_Lib:2.1.2aar置于底部布局&#xff08;最外层必须是RelativeLayout&#xff09;<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/a…

Arcgis10安装说明

1、 先安装dotnet framework 3.5 ,必须要装这个才能运行安装程序。 2、 接着安装Arcgis Desktop &#xff0c;只需下一步&#xff0c;下一步执行就好了。完成后&#xff0c;停掉服务。 3、 安装LicenseManager &#xff0c;下一步执行就可以。 4、 接着来破解&…

前端学习(2606):vue简单叙述

第一步 引入 第二步new Vue 第三步 data绑定数据

wux-button 样式扩展 增加shape属性

1、原来的写法和界面图如下 <wux-button block type"orange">拍照确认</wux-button>2、现在的写法只需要增加一个shape"round"参数&#xff0c;可以实现按钮边框为半圆 <wux-button block type"orange" shape"round"&g…

android webView注入js方法

需要在页面加载完成之后才能注入自定义js方法 webView.setWebViewClient(new WebViewClient() {Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) { // view.loadUrl(url);return true;//true时&#xff0c;不可点击跳页效果&…

前端框架Bootstrap简单介绍

下载&#xff1a; 解压之后&#xff1a; 把这些文件拷贝到项目中 页面使用时 只需要引入&#xff1a; 然后我们就可以参考官网来设计需要的前端页面了 设计一个按钮&#xff1a;button 只需要标明css样式中使用的类 下面就是现实效果&#xff1a; 转载于:https://www.cnblo…

CASS软件学习笔记

最近需要学习数据处理&#xff0c;用到的软件是Cass6.1 软件&#xff0c;下面我将学习中的笔记进行了整理。 1、Cass 6.1 支持是CAD2004 &#xff0d;2006&#xff0c;安装的话&#xff0c;先装CAD&#xff0c;然后破解&#xff0c;再装Cass &#xff0c;然后打上补丁&#xf…

vue学习中遇到的错误 Duplicate keys detected: ‘[object Object]‘. This may cause an update error.

前端入门自学&#xff0c;说错的请大神指点。 Avoid using non-primitive value as key, use string/number value instead. Duplicate keys detected: ‘[object Object]’. This may cause an update error.运行后出现这些警告&#xff0c;意思是检测到重复的键值。 把:key里…

mongoose 数据库设计千万要注意 Cast to [number] failed for value

不要定义字段type balance_flow: [{// 提现金额money: { type: Number },// 资金类型 0>提现 withdraw 1>资金流入 user_activetype: Number}],这样会报错

Linux Shell中有三种引号的用法

Linux Shell中有三种引号&#xff0c;分别为双引号&#xff08;" "&#xff09;、单引号( )以及反引号( )。 其中双引号对字符串中出现的$、、和\进行替换&#xff1b;单引号不进行替换&#xff0c;将字符串中所有字符作为普通字符输出&#xff0c;而反引号中字符串作…

工作113:添加echart折线图

<template><div><el-card><div slot"header" class"clearfix"><span>订单信息</span></div><!--样式控制全部 已经退回 待审核--><el-row><el-radio-group v-model"query.status" siz…

测试管理

测试管理工作检查表&#xff1a; 1. 检查每轮测试开始时测试环境是否准备好&#xff08;包括软件硬件、测试基本数据等&#xff09;&#xff1b; 2. 确保测试环境&#xff08;数据和程序&#xff09;与开发分离&#xff0c;除了测试组之外其他人不能更新测试环境的数据和程序…

android 获取webView高度,设置webView高度

1、注入获取webView高度的js方法 webView.setWebViewClient(new WebViewClient() {Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) { // view.loadUrl(url);return true;//true时&#xff0c;不可点击跳页效果&#xff0c;false时…

如何设计一个高并发系统

如何设计一个高并发系统&#xff1f; 如果你确实有真才实学&#xff0c;在互联网公司里&#xff0c;干过高并发系统&#xff0c;那你拿Offer&#xff0c;基本如探囊取物一样简单。 但你要真干过高并发系统&#xff0c;面试官绝对不会问这个问题&#xff0c;否则他就不太明智了…

李超线段树 [Heoi2013]Segment

问题 D: [Heoi2013]Segment 时间限制: 4 Sec 内存限制: 256 MB 题目描述 要求在平面直角坐标系下维护两个操作&#xff1a; 1.在平面上加入一条线段。记第i条被插入的线段的标号为i。 2.给定一个数k,询问与直线 x k相交的线段中&#xff0c;交点最靠上的线段的编号。 输…

Android 城市选择,热门城市,全部城市(美团、滴滴、淘宝)

demo链接&#xff1a;https://download.csdn.net/download/meixi_android/10819638 实现效果&#xff1a; 实现方法&#xff1a;非常简洁快速&#xff0c;三步集成实现地区选择器 1、导入city.module module导入方法&#xff1a;https://blog.csdn.net/meixi_android/articl…

虚拟化资料

很感谢 http://pan.baidu.com/netdisk/extractpublic?uk503876868#dir

汽车列表 车型选择 源码备忘

因为版权问题&#xff0c;选汽车的时候不能显示汽车自己真实的图片&#xff0c;下面我需要改成列表形式&#xff0c;下面记录一下代码 1、实现效果 2、源码 <div class"car-brand-list"><div v-for"(brand,index) in brandList" :key"inde…