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;
}
相关推荐
AndrewHZ9 小时前
【复杂网络分析】如何入门Louvain算法?
python·算法·复杂网络·社区发现·community det·louvain算法·图挖掘
AndrewHZ9 小时前
【图像处理基石】如何基于黑白图片恢复出色彩?
图像处理·深度学习·算法·计算机视觉·cv·色彩恢复·deoldify
POLITE39 小时前
Leetcode 3.无重复字符的最长子串 JavaScript (Day 4)
javascript·算法·leetcode
Xの哲學9 小时前
Linux IPC机制深度剖析:从设计哲学到内核实现
linux·服务器·网络·算法·边缘计算
sin_hielo9 小时前
leetcode 756(枚举可填字母)
算法·leetcode
Jeremy爱编码9 小时前
leetcode热题子集
算法·leetcode·职场和发展
csg11079 小时前
LORA网络的“最后一公里”难题:当信号被重重阻挡,我们有哪些“方法”来增强覆盖?
单片机·嵌入式硬件·物联网·算法
brave and determined9 小时前
传感器学习(day18):智能手机3D结构光:解锁未来的第三只眼
嵌入式硬件·算法·3d·智能手机·tof·嵌入式设计·3d结构光
CoovallyAIHub9 小时前
当小龙虾算法遇上YOLO:如何提升太阳能电池缺陷检测精度?
深度学习·算法·计算机视觉
努力学算法的蒟蒻9 小时前
day48(12.29)——leetcode面试经典150
算法·leetcode·面试