HJ174 交换到最大

  • 题目
  • 题解(26)
  • 讨论(9)
  • 排行

简单 通过率:41.93% 时间限制:3秒 空间限制:256M

知识点贪心

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

给定一个仅由数字 0-90-9 构成的字符串 ss。一次操作可按如下方式进行:

∙ ∙ 从 ss 中选择既不是最左端字符也不为 00 的某一字符;

∙ ∙ 将该字符的数值减少 11;

∙ ∙ 随后把它与左侧相邻字符交换位置。

例如,字符串 "1023""1023" 经过一次操作可以变成 "1103""1103" 或 "1022""1022"。

你可以不限次数地执行上述操作。请计算能够得到的字典序最大的字符串,并输出该字符串。

输入描述:

第一行输入一个整数 t(1≦t≦104)t(1≦t≦104),表示测试用例数量。

此后 tt 行,每行输入一个不含前导零的数字字符串 ss,满足 1≦∣s∣≦2×1051≦∣s∣≦2×105。

保证所有测试用例的 ∣s∣∣s∣ 之和不超过 2×1052×105。

输出描述:

对于每个测试用例,在一行上输出通过任意次数操作后能够得到的字典序最大的字符串。

示例1

输入:

复制代码
6
19
1709
11555
51476
9876543210
5891917899

复制输出:

复制代码
81
6710
33311
55431
9876543210
7875567711

复制说明:

复制代码
以 "19""19" 为例:
∙ ∙ "19""19" →→ "89""89";
∙ ∙ "89""89" →→ "81""81",得到答案 "81""81"。

再以 "1709""1709" 为例,可按如下序列操作:
∙ ∙ "1709""1709" →→ "1780""1780";
∙ ∙ "1780""1780" →→ "6180""6180";
∙ ∙ "6180""6180" →→ "6710""6710",最终得到答案 "6710""6710"。
cpp 复制代码
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>

using namespace std;

void solve() {
    string s;
    cin >> s;
    int n = s.length();

    for (int i = 0; i < n; ++i) {
        int best_val = s[i] - '0';
        int best_pos = i;

        // 在窗口内寻找能产生最大价值的来源
        for (int j = i; j < min(i + 10, n); ++j) {
            int current_val = (s[j] - '0') - (j - i);
            if (current_val > best_val) {
                best_val = current_val;
                best_pos = j;
            }
        }

        // 物理移动来源字符到当前位置i
        while (best_pos > i) {
            swap(s[best_pos], s[best_pos - 1]);
            best_pos--;
        }
        
        // 将当前位置i的字符值更新为计算出的最优值
        s[i] = (char)(best_val + '0');
    }
    cout << s << endl;
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    int t;
    cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}
相关推荐
AI科技星2 小时前
基于v≡c第一性原理:密度的本质与时空动力学
人工智能·学习·算法·机器学习·数据挖掘
kishu_iOS&AI2 小时前
机器学习 —— 聚类算法
人工智能·算法·机器学习·聚类
hope_wisdom2 小时前
C/C++数据结构之树
数据结构·c++·二叉树·
FluxMelodySun2 小时前
机器学习(三十一) 半监督SVM与图半监督学习
人工智能·算法·机器学习
磊 子2 小时前
八大排序之插入排序+希尔排序
数据结构·算法·排序算法
kishu_iOS&AI2 小时前
机器学习 —— 逻辑回归(混淆矩阵)
人工智能·算法·机器学习·逻辑回归
W23035765732 小时前
经典算法:打家劫舍(动态规划 + 回溯求最优解)C++ 超详细解析
c++·算法·动态规划
Dev7z2 小时前
基于改进小波阈值的sEMG信号降噪与手势识别系统设计与实现
算法·手势识别·改进小波阈值·semg·信号降噪
灵感__idea9 小时前
Hello 算法:贪心的世界
前端·javascript·算法