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;
}
相关推荐
FMRbpm2 小时前
顺序表实现队列
数据结构·c++·算法·新手入门
飞天狗1112 小时前
G. Mukhammadali and the Smooth Array
数据结构·c++·算法
CQ_YM2 小时前
数据结构之树
数据结构·算法·
某林2122 小时前
SLAM 建图系统配置与启动架构
人工智能·stm32·单片机·嵌入式硬件·算法
不穿格子的程序员2 小时前
从零开始写算法——矩阵类题:图像旋转 + 搜索二维矩阵 II
线性代数·算法·矩阵
罗湖老棍子2 小时前
Knight Moves(信息学奥赛一本通- P1257)
c++·算法·bfs
AuroraWanderll3 小时前
C++11(二)核心突破:右值引用与移动语义(上)
c语言·数据结构·c++·算法·stl
CoderYanger3 小时前
第 479 场周赛Q1——3769. 二进制反射排序
java·数据结构·算法·leetcode·职场和发展
广府早茶3 小时前
机器人重量
c++·算法