博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 5071 Chat(模拟)
阅读量:6279 次
发布时间:2019-06-22

本文共 2842 字,大约阅读时间需要 9 分钟。

题目大意:模拟题。

。。

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

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

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

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

#include 
#include
#include
#include
#include
using namespace std;const int maxn = 5005;typedef long long ll;map
C;int x, N, A[maxn], T, flag;vector
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; }

转载地址:http://jtnva.baihongyu.com/

你可能感兴趣的文章
正文提取算法
查看>>
轻松学PHP
查看>>
Linux中的网络监控命令
查看>>
this的用法
查看>>
windows下安装redis
查看>>
CentOS7 yum 安装git
查看>>
启动日志中频繁出现以下信息
查看>>
httpd – 对Apache的DFOREGROUND感到困惑
查看>>
分布式锁的一点理解
查看>>
idea的maven项目,install下载重复下载本地库中已有的jar包,而且下载后jar包都是lastupdated问题...
查看>>
2019测试指南-web应用程序安全测试(二)指纹Web服务器
查看>>
树莓派3链接wifi
查看>>
js面向对象编程
查看>>
Ruby中类 模块 单例方法 总结
查看>>
jQuery的validate插件
查看>>
5-4 8 管道符 作业控制 shell变量 环境变量配置
查看>>
Enumberable
查看>>
开发者论坛一周精粹(第五十四期) 求购备案服务号1枚!
查看>>
validate表单验证及自定义方法
查看>>
javascript 中出现missing ) after argument list的错误
查看>>