zoukankan      html  css  js  c++  java
  • CodeForces 1281B(思维+暴力)

    B. Azamon Web Services
    time limit per test
    2 seconds
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Your friend Jeff Zebos has been trying to run his new online company, but it's not going very well. He's not getting a lot of sales on his website which he decided to call Azamon. His big problem, you think, is that he's not ranking high enough on the search engines. If only he could rename his products to have better names than his competitors, then he'll be at the top of the search results and will be a millionaire.

    After doing some research, you find out that search engines only sort their results lexicographically. If your friend could rename his products to lexicographically smaller strings than his competitor's, then he'll be at the top of the rankings!

    To make your strategy less obvious to his competitors, you decide to swap no more than two letters of the product names.

    Please help Jeff to find improved names for his products that are lexicographically smaller than his competitor's!

    Given the string ss representing Jeff's product name and the string cc representing his competitor's product name, find a way to swap at most one pair of characters in ss (that is, find two distinct indices ii and jj and swap sisi and sjsj) such that the resulting new name becomes strictly lexicographically smaller than cc, or determine that it is impossible.

    Note: String aa is strictly lexicographically smaller than string bb if and only if one of the following holds:

    • aa is a proper prefix of bb, that is, aa is a prefix of bb such that aba≠b;
    • There exists an integer 1imin(|a|,|b|)1≤i≤min(|a|,|b|) such that ai<biai<bi and aj=bjaj=bj for 1j<i1≤j<i.
    Input

    The first line of input contains a single integer tt (1t15001≤t≤1500) denoting the number of test cases. The next lines contain descriptions of the test cases.

    Each test case consists of a single line containing two space-separated strings ss and cc (2|s|5000,1|c|50002≤|s|≤5000,1≤|c|≤5000). The strings ss and cc consists of uppercase English letters.

    It is guaranteed that the sum of |s||s| in the input is at most 50005000 and the sum of the |c||c| in the input is at most 50005000.

    Output

    For each test case, output a single line containing a single string, which is either

    • the new name which is obtained after swapping no more than one pair of characters that is strictly lexicographically smaller than cc. In case there are many possible such strings, you can output any of them;
    • three dashes (the string "---" without quotes) if it is impossible.
    Example
    input
    Copy
    3
    AZAMON APPLE
    AZAMON AAAAAAAAAAALIBABA
    APPLE BANANA
    
    output
    Copy
    AMAZON
    ---
    APPLE
    
    Note

    In the first test case, it is possible to swap the second and the fourth letters of the string and the resulting string "AMAZON" is lexicographically smaller than "APPLE".

    It is impossible to improve the product's name in the second test case and satisfy all conditions.

    In the third test case, it is possible not to swap a pair of characters. The name "APPLE" is lexicographically smaller than "BANANA". Note that there are other valid answers, e.g., "APPEL".

    题意:T组测试数据,每组测试数据两个字符串a,c。最多只可以最多对a数组进行一个操作,即交换两个字符,使得a数组字典序大小严格小于c。如果存在这个结果,输出其中一个即可,否则输出---。

    思路:wa了无数次思路错误。题意实际就是问,对一个字符串只进行1或者0次交换两个字符的操作,使得其字符串字典序最小,是多少?

    将a赋值为b,对b进行排序,便利从头到尾,找到不相等的一个位置p,保存下来。再从后往前遍历a,倘若找到了这个被保存的数,变把这个数a[i]和a[p]交换,再判断字典序大小即可。。

    几个测试数据

    BAH BA

    QA AQH

    QABC AQBCH

    QAB AQ

    附AC代码

    #include <iostream>
    #include <cmath>
    #include <cstdio>
    #include <cstring>
    #include <string>
    #include <map>
    #include <iomanip>
    #include <algorithm>
    #include <queue>
    #include <stack>
    #include <set>
    #include <vector>
    //const int maxn = 1e5+5;
    #define ll long long
    #define inf  0x3f3f3f3f
    #define FOR(i,a,b) for( int i = a;i <= b;++i)
    #define bug cout<<"--------------------------------------------"<<endl
     
    ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
    ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
    const int maxn = 100100;
    using namespace std;
     string a,b,c;
    int k,flag,len,hhh;
     
    int main()
    {
        int T;
        cin>>T;
        while(T--)
        {
            cin>>a>>c;
            b = a;
            char temp = 1;
            sort(b.begin(),b.end());
            int pos = 0;
            for(int i = 0 ;i <a.length();++i)
            {
                if(a[i] != b[i])
                {
                    temp = b[i];
                    pos = i;
                    break;
                }
            }
            for(int i = a.length()-1; i >= 0; --i)
            {
                if(temp == a[i]){
                    char hhh = a[i];
                    a[i] = a[pos];
                    a[pos] = hhh;
                }
            }
            if(a < c) cout<<a<<endl;
            else cout<<"---"<<endl;
        }
     
    }
  • 相关阅读:
    ***25 k个一组反转链表
    24 交换链表中相连的节点
    19 删除链表倒数第N个节点
    2 两数相加
    23 合并K个有序链表
    21 合并两个有序链表
    114 判断一个链表是否存在环并返回环起点
    141 链表是否存在环
    160 寻找链表交点
    92 指定区间链表逆置
  • 原文地址:https://www.cnblogs.com/jrfr/p/12073245.html
Copyright © 2011-2022 走看看