codeforces 140B.New Year Cards 解题报告
题目链接:http://codeforces.com/problemset/problem/140/B
题目意思:给出 Alexander 和他的 n 个朋友的 preference lists:数字 1~n 的排列。现在Alexander 需要遵循两条rules向他的 朋友发送贺卡。
1、他不会send 和 该朋友给他的一模一样的贺卡。
2、对于当前他所拥有的贺卡,他只会选择他自己最喜欢的卡给朋友。
同一张卡可以使用多次,而且尽量使得他的朋友满意,也就是尽量满足该朋友的 preference lists。
现在需要找出一条 send card 的 schedule,表示某个 moment 下应该send card 到某个friend中。
正如题解所说,这条题目难就难在模拟上。因为Alexander 某个时刻的决策受到两个因素的影响:他自己本人的preference list 以及他朋友的preference list 的影响。而且 Alexander 的preference list 随着时间的推移是有所改变的。所以我们希望在尽量不使得他朋友的preference list 太差的情况下,按照题目所说的,运用那两条rule.
排除 send 同 receive 是同 一 张卡并不困难,因为 编号为 i 的人send card 的时刻正是 i ,也就是编号为 i 的卡!不等于 i 即可。然后就是考虑对该朋友应该send 哪张卡了:对朋友的preference list 的每个数都check 下 Alexander 的preference list 中哪个数可以派发。(说不下去了,以下是请教乌冬子后整理的)
引用如下(白话文,请见谅),思路代码都非常清晰!
/*****************************
对于每个朋友,都枚举出所有alex可能发出既卡片,然后从中选出呢个朋友比较中意既就得
其实喜爱列表作用就系话比我地知,有滴卡系永远唔会寄出去
我地用朋友既角度去捻,最好既结果就系拿到alex可能寄出卡里面,自己最喜爱果张
注意到alex可以系任何时刻发卡片,所以枚举可能寄出卡片方法就系求出alex每日会寄出既卡片就得,因为有rule2所以我地要针对每个人求,例如,第一个例子,对于朋友1,alex每日寄出既卡系0,2,3,3,3,对于朋友2,每日寄出既卡片系1,1,3,3,3,朋友3系1,1,3,3,3 如此类推
********************************/
他的代码,就是按这个思路写的,我改了下下标,省去了一些处理,命名也改了下。
#include <cstdlib>
#include <cstdio>
#include <iostream>
#include <vector>
using namespace std; const int N = 3e2 + ; int n, fri_pref[N][N]; int main()
{
cin.sync_with_stdio();
while (cin >> n) {
for (int i = ; i <= n; i++)
for (int j = ; j <= n; j++) {
cin >> fri_pref[i][j];
} int Alex_pref[N];
for (int i = ; i <= n; i++) {
int input;
cin >> input;
Alex_pref[input] = i; // 标出Alex表的喜好编号顺序
} int res[N];
for (int i = ; i <= n; i++) //
{
bool h[N] = {false};
int now = -;
for (int j = ; j <= n; j++) // Alex 表
{
if (j == i || (~now && Alex_pref[j] > Alex_pref[now])) // ~now 即 now != -1,枚举Alex每日对i这个人寄出的卡片,且排除了Alex一定派不出去的卡
continue;
now = j;
h[now] = true;
} for (int j = ; j <= n; j++)
{
if (!h[fri_pref[i][j]])
continue;
res[i] = fri_pref[i][j];
break;
}
} for (int i = ; i < n; i++)
cout << res[i] << " ";
cout << res[n] << endl;
} return ;
}
codeforces 140B.New Year Cards 解题报告的更多相关文章
- Codeforces Educational Round 92 赛后解题报告(A-G)
Codeforces Educational Round 92 赛后解题报告 惨 huayucaiji 惨 A. LCM Problem 赛前:A题嘛,总归简单的咯 赛后:A题这种**题居然想了20m ...
- codeforces 476C.Dreamoon and Sums 解题报告
题目链接:http://codeforces.com/problemset/problem/476/C 题目意思:给出两个数:a 和 b,要求算出 (x/b) / (x%b) == k,其中 k 的取 ...
- Codeforces Round #382 (Div. 2) 解题报告
CF一如既往在深夜举行,我也一如既往在周三上午的C++课上进行了virtual participation.这次div2的题目除了E题都水的一塌糊涂,参赛时的E题最后也没有几个参赛者AC,排名又成为了 ...
- codeforces 471C.MUH and House of Cards 解题报告
题目链接:http://codeforces.com/problemset/problem/471/C 题目意思:有 n 张卡,问能做成多少种不同楼层(floor)的 house,注意这 n 张卡都要 ...
- codeforces 507B. Amr and Pins 解题报告
题目链接:http://codeforces.com/problemset/problem/507/B 题目意思:给出圆的半径,以及圆心坐标和最终圆心要到达的坐标位置.问最少步数是多少.移动见下图.( ...
- codeforces 500B.New Year Permutation 解题报告
题目链接:http://codeforces.com/problemset/problem/500/B 题目意思:给出一个含有 n 个数的排列:p1, p2, ..., pn-1, pn.紧接着是一个 ...
- codeforces B. Xenia and Ringroad 解题报告
题目链接:http://codeforces.com/problemset/problem/339/B 题目理解不难,这句是解题的关键 In order to complete the i-th ta ...
- codeforces 462C Appleman and Toastman 解题报告
题目链接:http://codeforces.com/problemset/problem/461/A 题目意思:给出一群由 n 个数组成的集合你,依次循环执行两种操作: (1)每次Toastman得 ...
- codeforces 460A Vasya and Socks 解题报告
题目链接:http://codeforces.com/problemset/problem/460/A 题目意思:有一个人有 n 对袜子,每天早上会穿一对,然后当天的晚上就会扔掉,不过他会在 m 的倍 ...
随机推荐
- [功能集锦] 001 - java下载文件
@RequestMapping("/downloadxls.action") public void downloadxls(HttpServletRequest request, ...
- memcachq队列安装
memcacheq是集中的队列小软件,使用起来简单,便捷,高效. 下载 http://git.oschina.net/sgfoot/linux-tools/raw/master/memcacheq-0 ...
- xcode5 asset catalogs 由于图标尺寸错误导致编译问题解决[原创]
如下图,即使图片尺寸不规范,xcode5也可以正常预览(这里我提供的尺寸是57*57, 而需要的是120*120) 但编译运行失败,报的错是: Images.xcassets: error: The ...
- xcode创建一个工程的多个taget,便于测试和发布多个版本
背景:很多时候,我们需要在一个工程中创立多个target,也就是说我们希望同一份代码可以创建两个应用,放到模拟器或者真机上,或者是,我们平时有N多人合作开发,当测试的时候,在A这里装了一遍测A写的那块 ...
- Android 实现Activity后台运行
有时需要让activity在后台运行,具体实现方法如下: 在AndroidManifest.xml中,activity属性中增加: android:theme="@style/Backgro ...
- 全文索引-lucene,solr,nutch,hadoop之nutch与hadoop
全文索引-lucene.solr.nutch,hadoop之lucene 全文索引-lucene.solr,nutch,hadoop之solr 我在去年的时候,就想把lucene,solr.nutch ...
- 线程安全使用(四) [.NET] 简单接入微信公众号开发:实现自动回复 [C#]C#中字符串的操作 自行实现比dotcore/dotnet更方便更高性能的对象二进制序列化 自已动手做高性能消息队列 自行实现高性能MVC WebAPI 面试题随笔 字符串反转
线程安全使用(四) 这是时隔多年第四篇,主要是因为身在东软受内网限制,好多文章就只好发到东软内部网站,懒的发到外面,现在一点点把在东软写的文章给转移出来. 这里主要讲解下CancellationT ...
- C结构体对齐
函数模板针对仅参数类型不同的函数? http://blog.csdn.net/renrenhappy/article/details/5931457 计算结构体的大小就要考虑数据对齐问题. ...
- Quartz 2D编程指南(2)图形上下文(Graphics Contexts)
Graphics Contexts 一个Graphics Context表示一个绘制目标(也能够理解为图形上下文).它包括绘制系统用于完毕绘制指令的绘制參数和设备相关信息.Graphics ...
- 李洪强iOS开发之 - 项目架构
李洪强iOS开发之 - 项目架构 01 - 在Appdelegate中设置跟控制器 //导入头文件