zoukankan      html  css  js  c++  java
  • Codeforces Round #623 (Div. 2, based on VK Cup 2019-2020

    After a long party Petya decided to return home, but he turned out to be at the opposite end of the town from his home. There are n crossroads in the line in the town, and there is either the bus or the tram station at each crossroad.

    The crossroads are represented as a string s of length n, where si=A, if there is a bus station at i-th crossroad, and si=B, if there is a tram station at i-th crossroad. Currently Petya is at the first crossroad (which corresponds to s1) and his goal is to get to the last crossroad (which corresponds to sn).

    If for two crossroads i and j for all crossroads i,i+1,…,j−1 there is a bus station, one can pay a roubles for the bus ticket, and go from i-th crossroad to the j-th crossroad by the bus (it is not necessary to have a bus station at the j-th crossroad). Formally, paying a roubles Petya can go from i to j if st=A for all i≤t<j.

    If for two crossroads i and j for all crossroads i,i+1,…,j−1 there is a tram station, one can pay b roubles for the tram ticket, and go from i-th crossroad to the j-th crossroad by the tram (it is not necessary to have a tram station at the j-th crossroad). Formally, paying b roubles Petya can go from i to j if st=B for all i≤t<j.

    For example, if s=“AABBBAB”, a=4 and b=3 then Petya needs:

    buy one bus ticket to get from 1 to 3,
    buy one tram ticket to get from 3 to 6,
    buy one bus ticket to get from 6 to 7.
    Thus, in total he needs to spend 4+3+4=11 roubles. Please note that the type of the stop at the last crossroad (i.e. the character sn) does not affect the final expense.

    Now Petya is at the first crossroad, and he wants to get to the n-th crossroad. After the party he has left with p roubles. He’s decided to go to some station on foot, and then go to home using only public transport.

    Help him to choose the closest crossroad i to go on foot the first, so he has enough money to get from the i-th crossroad to the n-th, using only tram and bus tickets.

    Input
    Each test contains one or more test cases. The first line contains the number of test cases t (1≤t≤104).

    The first line of each test case consists of three integers a,b,p (1≤a,b,p≤105) — the cost of bus ticket, the cost of tram ticket and the amount of money Petya has.

    The second line of each test case consists of one string s, where si=A, if there is a bus station at i-th crossroad, and si=B, if there is a tram station at i-th crossroad (2≤|s|≤105).

    It is guaranteed, that the sum of the length of strings s by all test cases in one test doesn’t exceed 105.

    Output
    For each test case print one number — the minimal index i of a crossroad Petya should go on foot. The rest of the path (i.e. from i to n he should use public transport).
    这个题倒着从后向前模拟,模拟题傻逼

    #include <bits/stdc++.h>
    using namespace std;
    char s[100000];
    long long  a, b, p,t;
    long long solve()
    {
         int l = strlen(s + 1);
            int cnt = 0;
            int u = 0;
            for (int i = l; i >= 2; i--)
            {
                if (u == 0)
                {
                    if (s[i - 1] == 'A')
                    {
                        if (p >= a)
                        {
                            p -= a;
                            u = 1;
                            cnt++;
                        }
                        else
                            break;
                    }
                    if (s[i - 1] == 'B')
                    {
                        if (p >= b)
                        {
                            p -= b;
                            u = 2;
                            cnt++;
                        }
                        else
                            break;
                    }
                }
                else if (u == 1)
                {
                    if (s[i - 1] == 'B')
                    {
                        if (p >= b)
                        {
                            p -= b;
                            u = 2;
                            cnt++;
                        }
                        else
                            break;
                    }
                    else
                        cnt++;
                }
                else if (u == 2)
                {
                    if (s[i - 1] == 'A')
                    {
                        if (p >= a)
                        {
                            p -= a;
                            u = 1;
                            cnt++;
                        }
                        else
                            break;
                    }
                    else
                        cnt++;
                }
            }
            return  l - cnt;
    }
    int main()
    {
        cin >> t;
        while (t--)
        {
            
            cin >> a >> b >> p;
            scanf("%s", s + 1);
           cout<<solve()<<endl;
        }
    }
    
  • 相关阅读:
    关于本Blog无法进行评论问题的说明
    Apusic Operamasks例子部署过程
    JVM启动参数(转)
    20070724中间件产品培训方式总结
    写Blog的意义
    磁碟機讀取光碟片時遇故障7/9
    .aspx沒有語言擴充功能8/14
    水晶報表公式的dateadd及cstr應用7/11
    中毒了:Trojar6/26
    學位英語考試通過啦8/28
  • 原文地址:https://www.cnblogs.com/lunatic-talent/p/12798418.html
Copyright © 2011-2022 走看看