C. Needle in a Haystack

C. Needle in a Haystackhttps://codeforces.com/contest/2175/problem/C

目录

题意:

思路:

代码:


题意:

给定两个字符串s和t,问如何对t进行排列,可以使得t的子序列中存在s,输出字典序最小的那个排列方式,如果不存在这种排列,则输出"Impossible"

思路:

先判断t中是否有s

如果有,先把s从t中剔出来,然后对剩下的t进行排序

然后再用此时的t和s依次从头元素进行比较

二者不相同的话选小的(显而易见)

二者相同选s的头**(t是有序的,但是s不是有序的,有可能s的头后面的元素比s的头要小,此时我们先放s的头,尽可能把后面小的元素往前挪)**

代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
// priority_queue<int, vector<int>, greater<int> > q;
const int N = 4e5+10;
const int inf=1e9;
void solve() {
    string s1,s2;
    cin >> s1 >> s2;
    int a[300]={0};
    for(int i=0;i<s1.size();i++) {
        a[(int)s1[i]]++;
    }
    vector<char> p;
    for (int i=0;i<s2.size();i++) {
        if (a[(int)s2[i]]) {
            a[(int)s2[i]]--;
        }
        else {
            p.push_back(s2[i]);
        }
    }
    sort(a,a+300);
    if (a[299]) {
        cout << "Impossible" << endl;
        return ;
    }
    sort(p.begin(),p.end());
    int j=0,k=0;
    for (;j<s1.size()&&k<p.size();) {
        if (s1[j]<p[k]) {
            cout << s1[j] ;j++;
        }else if (s1[j]>p[k]) {
            cout << p[k] ;k++;
        }else {
            cout << s1[j] ;j++;
        }
    }
    if (j<s1.size()) {
        for (int i=j;i<s1.size();i++){
            cout << s1[i];
        }

    }else {
        for (int i=k;i<p.size();i++){
            cout << p[i];
        }
    }
    cout << endl;
}

signed main() {
    int q;
    cin >> q;
    while (q--) {
        solve();
    }
    return 0;
}
相关推荐
君义_noip8 小时前
信息学奥赛一本通 1661:有趣的数列 | 洛谷 P3200 [HNOI2009] 有趣的数列
c++·算法·组合数学·信息学奥赛·csp-s
程序员:钧念8 小时前
深度学习与强化学习的区别
人工智能·python·深度学习·算法·transformer·rag
英英_9 小时前
MATLAB数值计算基础教程
数据结构·算法·matlab
一起养小猫9 小时前
LeetCode100天Day14-轮转数组与买卖股票最佳时机
算法·leetcode·职场和发展
hele_two10 小时前
快速幂算法
c++·python·算法
l1t10 小时前
利用DeepSeek将python DLX求解数独程序格式化并改成3.x版本
开发语言·python·算法·数独
jllllyuz10 小时前
基于子集模拟的系统与静态可靠性分析及Matlab优化算法实现
算法·matlab·概率论
程序员-King.11 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
BlockChain88811 小时前
字符串最后一个单词的长度
算法·go
爱吃泡芙的小白白11 小时前
深入解析:2024年AI大模型核心算法与应用全景
人工智能·算法·大模型算法