HDOJ 5071: Chat

题目链接:

http://acm.hdu.edu.cn/showproblem.php?pid=5071

题意:

模拟QQ窗口聊天序列的若干操作,输出结果。

算法:

模拟。

直接用一个vector或者queue来模拟窗口序列。

另外找一个数组或map来记录说的词的数量。

额外用一个变量来记录当前“always on top”的是谁。

代码:

#include <cstdio>
#include <vector>
#include <map>
using namespace std;

char command[20];
vector<int> a;
map<int, long long> cot;
int top;

inline int get_top()
{
    if (top != -1)
    {
        return top;
    }
    if (!a.empty())
    {
        return a[0];
    }
    return -1;
}

inline int index_of(int x)
{
    for (int i = 0; i < a.size(); i ++)
    {
        if (a[i] == x)
        {
            return i;
        }
    }
    return -1;
}

inline void move_first(int x)
{
    int tmp = a[x];
    for (int i = x; i > 0; i --)
    {
        a[i] = a[i - 1];
    }
    a[0] = tmp;
}

int main()
{
    int cas;
    scanf("%d", &cas);
    while (cas --)
    {
        int n;
        scanf("%d", &n);
        a.clear();
        cot.clear();
        top = -1;
        for (int tot = 1; tot <= n; tot ++)
        {
            scanf("%s", command);
            printf("Operation #%d: ", tot);
            if (command[0] == 'A')
            {
                int x;
                scanf("%d", &x);
                if (cot.find(x) != cot.end())
                {
                    puts("same priority.");
                }
                else
                {
                    a.push_back(x);
                    cot[x] = 0;
                    puts("success.");
                }
            }
            else if ((command[0] == 'C') && (command[1] == 'l'))
            {
                int x;
                scanf("%d", &x);
                if (cot.find(x) != cot.end())
                {
                    if (top == x)
                    {
                        top = -1;
                        if (cot[x] > 0)
                        {
                            printf("Bye %d: %I64d\n", x, cot[x]);
                        }
                    }
                    printf("close %d with %I64d.\n", x, cot[x]);
                    for (int i = index_of(x); i + 1 < a.size(); i ++)
                    {
                        a[i] = a[i + 1];
                    }
                    a.pop_back();
                    cot.erase(x);
                }
                else
                {
                    puts("invalid priority.");
                }
            }
            else if ((command[0] == 'C') && (command[1] == 'h') && (command[2] == 'a'))
            {
                int c;
                scanf("%d", &c);
                if (!a.empty())
                {
                    cot[get_top()] += c;
                    puts("success.");
                }
                else
                {
                    puts("empty.");
                }
            }
            else if (command[0] == 'R')
            {
                int x;
                scanf("%d", &x);
                if (x <= a.size())
                {
                    move_first(x - 1);
                    puts("success.");
                }
                else
                {
                    puts("out of range.");
                }
            }
            else if (command[0] == 'P')
            {
                if (!a.empty())
                {
                    int x = 0;
                    for (int i = 0; i < a.size(); i ++)
                    {
                        if (a[i] > a[x])
                        {
                            x = i;
                        }
                    }
                    move_first(x);
                    puts("success.");
                }
                else
                {
                    puts("empty.");
                }
            }
            else if ((command[0] == 'C') && (command[1] == 'h') && (command[2] == 'o'))
            {
                int x;
                scanf("%d", &x);
                int index = index_of(x);
                if (index != -1)
                {
                    move_first(index);
                    puts("success.");
                }
                else
                {
                    puts("invalid priority.");
                }
            }
            else if (command[0] == 'T')
            {
                int x;
                scanf("%d", &x);
                if (cot.find(x) != cot.end())
                {
                    top = x;
                    puts("success.");
                }
                else
                {
                    puts("invalid priority.");
                }
            }
            else if (command[0] == 'U')
            {
                if (top != -1)
                {
                    top = -1;
                    puts("success.");
                }
                else
                {
                    puts("no such person.");
                }
            }
        }
        if (top != -1)
        {
            if (cot[top] > 0)
            {
                printf("Bye %d: %I64d\n", top, cot[top]);
            }
        }
        for (int i = 0; i < a.size(); i ++)
        {
            int x = a[i];
            if ((x != top) && (cot[x] > 0))
            {
                printf("Bye %d: %I64d\n", x, cot[x]);
            }
        }
    }
    return 0;
}


1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、 4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.m或d论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值