题目链接:hdu 5071 Chat

题目大意:模拟题。

。。

注意最后说bye的时候仅仅要和讲过话的妹子说再见。

解题思路:用一个map记录每一个等级的妹子讲过多少话以及是否有这个等级的妹子。数组A和N记录等级的顺序,添加

删除等操作全然能够同过数组上的模拟,时间足够。

T和flag标记是否有置顶窗体。

#include <cstdio>
#include <cstring>
#include <map>
#include <vector>
#include <algorithm> using namespace std; const int maxn = 5005;
typedef long long ll; map<int, ll> C;
int x, N, A[maxn], T, flag;
vector<int> vec; int find(int a) {
for (int i = 0; i < N; i++)
if (A[i] == a)
return i;
return N;
} void add () {
scanf("%d", &x);
if (C.count(x))
printf("same priority");
else {
A[N++] = x;
C[x] = 0;
printf("success");
}
} void close() {
scanf("%d", &x);
if (C.count(x)) {
printf("close %d with %I64d", x, C[x]);
C.erase(x); if (flag && T == x)
flag = 0; int pos = find(x);
for (int i = pos; i < N; i++)
A[i] = A[i+1];
N--;
} else
printf("invalid priority");
} void chat() {
scanf("%d", &x);
if (N == 0)
printf("empty");
else {
if (flag) {
C[T] += x;
vec.push_back(T);
} else {
C[A[0]] += x;
vec.push_back(A[0]);
}
printf("success");
}
} void rotate() {
scanf("%d", &x);
if (x > N || x < 1)
printf("out of range");
else {
int tmp = A[x-1];
for (int i = x-1; i; i--)
A[i] = A[i-1];
A[0] = tmp;
printf("success");
}
} void prior() {
if (N == 0)
printf("empty");
else {
int x = A[0], pos = 0;
for (int i = 1; i < N; i++) {
if (A[i] > x) {
x = A[i];
pos = i;
}
} int tmp = A[pos];
for (int i = pos; i; i--)
A[i] = A[i-1];
A[0] = tmp;
printf("success");
}
} void choose() {
scanf("%d", &x);
if (C.count(x)) {
int pos = find(x); int tmp = A[pos];
for (int i = pos; i; i--)
A[i] = A[i-1];
A[0] = tmp;
printf("success");
} else
printf("invalid priority");
} void top() {
scanf("%d", &x);
if (C.count(x)) {
T = x;
flag = 1;
printf("success");
} else
printf("invalid priority");
} void untop() {
if (flag) {
flag = 0;
printf("success");
} else
printf("no such person");
} void solve() {
if (N == 0)
return; if (flag && C[T])
printf("Bye %d: %I64d\n", T, C[T]); for (int i = 0; i < N; i++) {
if (flag && A[i] == T)
continue;
if (C[A[i]])
printf("Bye %d: %I64d\n", A[i], C[A[i]]);
} /*
int t = flag ? T : A[0];
if (C[t])
printf("Bye %d: %I64d\n", t, C[t]); for (int i = vec.size() - 1; i >= 0; i--) {
if (C.count(vec[i]) && t != vec[i]) {
printf("Bye %d: %I64d\n", vec[i], C[vec[i]]);
break;
}
}
*/
} int main () {
int cas;
scanf("%d", &cas);
while (cas--) {
N = T = flag = 0;
vec.clear();
C.clear(); int Q;
char op[10];
scanf("%d", &Q);
for (int i = 1; i <= Q; i++) {
scanf("%s", op);
printf("Operation #%d: ", i);
if (strcmp(op, "Add") == 0)
add();
else if (strcmp(op, "Close") == 0)
close();
else if (strcmp(op, "Chat") == 0)
chat();
else if (strcmp(op, "Rotate") == 0)
rotate();
else if (strcmp(op, "Prior") == 0)
prior();
else if (strcmp(op, "Choose") == 0)
choose();
else if (strcmp(op, "Top") == 0)
top();
else if (strcmp(op, "Untop") == 0)
untop();
printf(".\n");
}
solve();
}
return 0;
}

hdu 5071 Chat(模拟)的更多相关文章

  1. hdu 5071 Chat(模拟|Splay)

    Chat Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) Total Sub ...

  2. HDU 5071 Chat(2014鞍山B,模拟)

    http://acm.hdu.edu.cn/showproblem.php?pid=5071 Chat Time Limit: 2000/1000 MS (Java/Others)    Memory ...

  3. HDU - 5071 Chat(模拟)

    原题链接 题意:有各种操作,模拟这个程序并输出每次操作的信息 分析:恶心模拟题...用个map记录一下各个等级女孩的谈话数,同时也便于查找权值为u的在不在队列里.因为n很小,其他就暴力模拟了. #in ...

  4. HDU 5071 Chat(2014鞍山赛区现场赛B题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5071 解题报告:一个管理聊天窗口的程序,一共有八种操作,然后要注意的就是Top操作只是把编号为u的窗口 ...

  5. HDOJ 5071 Chat 模拟

    大模拟: 1>saygoodbye要先对 always on top 的人说 2>对没有说过话的不要说good bye 3>用long long Chat Time Limit: 2 ...

  6. HDU 5071 Chat

    题意: CLJ找了很多妹子-  (题目好没节操-)  对于CLJ和妹子的聊天对话框  有一下几种操作: add  加一个妹子在聊天窗队列末尾  假设这个妹子已经在队列中则add失败 close  关掉 ...

  7. hdu 5071 Chat-----2014acm亚洲区域赛鞍山 B题

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5071 Chat Time Limit: 2000/1000 MS (Java/Others)    M ...

  8. hdu 5071(2014鞍山现场赛B题,大模拟)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5071 思路:模拟题,没啥可说的,移动的时候需要注意top的变化. #include <iostr ...

  9. hdu 5071 vector操作恶心模拟

    http://acm.hdu.edu.cn/showproblem.php?pid=5071 对于每一个窗口,有两个属性:优先级+说过的单词数,支持8个操作:新建窗口,关闭窗口并输出信息,聊天(置顶窗 ...

随机推荐

  1. HTML文档类型DTD与浏览器怪异模式

    虽然在兼容IE6时候经常会注意到两个模式的区别,但是系统的理解起来,还没有认真总结过.看了一些网上的资料.结合自己的理解汇总了一下,放在这里备忘并分享给大家. 浏览器从服务端获取网页后会根据文档的DO ...

  2. Ubuntu环境下SSH的安装及使用

    Ubuntu环境下SSH的安装及使用 SSH是指Secure Shell,是一种安全的传输协议,Ubuntu客户端可以通过SSH访问远程服务器 .SSH的简介和工作机制可参看上篇文章SSH简介及工作机 ...

  3. cocos2d-x游戏开发系列教程-坦克大战游戏关卡选择场景的编写下

    上篇文章写了Paddle类来处理精灵的点击.触摸事件,现在我们在Paddle的基础上 写一个MyPaddle类,来处理上一关.下一关.开始游戏按钮的点击事件. 1.类声明如下: class MyPad ...

  4. android——写xml

    在PersonService的基础上,加上savePersons(·····),这时的PersonService为: package com.njupt.xml; import java.io.Fil ...

  5. Unity 3D学习笔记(三)——关于脚本

    在脚本中定义的类成员,如果是公共的话,在脚本与游戏对象绑定之后,是可以在Inspector中编辑的,例如下面这个脚本: using UnityEngine; using System.Collecti ...

  6. 如何使用Reaver破解Wi-Fi网络的WPA密码

    via: http://lifehacker.com/5873407/how-to-crack-a-wi+fi-networks-wpa-password-with-reaver 译者:Mr小眼儿 本 ...

  7. 【ASP.NET Web API教程】3 Web API客户端

    原文:[ASP.NET Web API教程]3 Web API客户端 Chapter 3: Web API Clients 第3章 Web API客户端 本文引自:http://www.asp.net ...

  8. 【翻译】ASP.NET Web API是什么?

    原文 [翻译]ASP.NET Web API是什么? 说明:随微软ASP.NET MVC 4一起发布的还有一个框架,叫做ASP.NET Web API.目前国内关注这项技术的人似乎还很少,这方面的文章 ...

  9. 一个与Log4j相关的死锁(转)

    这个死锁的原因:一个动作需要两个临界对象.静态同步方法,就是一个临界对象.这种场景,静态同步方法每次只能有一个线程持有.如果存在另一个临界对象,静态同步方法中也需要获取这个临界对象.即一个动作需要两个 ...

  10. Mac OS设置rootpassword

    不知怎么忘记mac os系统的rootpassword了 方法一: 首先,启动机器,启动时按住Apple和S键,以单用户模式(single user mode)进入系统.输入:mount -uw / ...