华为OD机试E卷 –字符串变换最小字符串 –24年OD统一考试(Java & JS & Python & C & C++)

文章目录

题目描述

给定一个字符串s,最多只能进行一次变换,返回变换后能得到的最小字符串(按照字典序进行比较)。 变换规则:交换字符串中任意两个不同位置的字符。

输入描述

一串小写字母组成的字符串s

输出描述

按照要求进行变换得到的最小字符串

用例

输入

abcdef

输出

abcdef

说明
abcdef已经是最小字符串,不需要交换

输入

bcdefa

输出

acdefb

说明
a和b进行位置交换,可以得到最小字符串

备注:
s是都是小写字符组成
1<=s.length<=1000

题目解析

  1. 遍历字符串:从左到右遍历字符串,找到第一个可以交换的位置。
  2. 寻找最小字符:对于每个字符,从当前位置之后的字符中找到最小的字符。
  3. 交换字符:如果找到的最小字符比当前字符小,则进行交换。
  4. 返回结果:如果进行了交换,返回交换后的字符串;如果没有进行交换,返回原字符串。

JS算法源码

```javascript
function getMinString(s) {
    let chars = s.split('');
    let n = chars.length;

    for (let i = 0; i < n - 1; i++) {
        let minChar = chars[i];
        let minIndex = i;

        for (let j = i + 1; j < n; j++) {
            if (chars[j] < minChar) {
                minChar = chars[j];
                minIndex = j;
            }
        }

        if (minIndex !== i) {
            [chars[i], chars[minIndex]] = [chars[minIndex], chars[i]];
            return chars.join('');
        }
    }

    return s;
}

// 示例输入
const s = "acb";
console.log(getMinString(s)); // 输出 "abc"

```

java算法源码

```java
public class Main {
    public static String getMinString(String s) {
        char[] chars = s.toCharArray();
        int n = chars.length;

        for (int i = 0; i < n - 1; i++) {
            char minChar = chars[i];
            int minIndex = i;

            for (int j = i + 1; j < n; j++) {
                if (chars[j] < minChar) {
                    minChar = chars[j];
                    minIndex = j;
                }
            }

            if (minIndex != i) {
                char temp = chars[i];
                chars[i] = chars[minIndex];
                chars[minIndex] = temp;
                return new String(chars);
            }
        }

        return s;
    }

    public static void main(String[] args) {
        String s = "acb";
        System.out.println(getMinString(s)); // 输出 "abc"
    }
}

```

python算法源码

```python
def get_min_string(s):
    chars = list(s)
    n = len(chars)

    for i in range(n - 1):
        min_char = chars[i]
        min_index = i

        for j in range(i + 1, n):
            if chars[j] < min_char:
                min_char = chars[j]
                min_index = j

        if min_index != i:
            chars[i], chars[min_index] = chars[min_index], chars[i]
            return ''.join(chars)

    return s

# 示例输入
s = "acb"
print(get_min_string(s))  # 输出 "abc"

```

c算法源码

```c
#include 
#include 

char* getMinString(char* s) {
    int n = strlen(s);

    for (int i = 0; i < n - 1; i++) {
        char minChar = s[i];
        int minIndex = i;

        for (int j = i + 1; j < n; j++) {
            if (s[j] < minChar) {
                minChar = s[j];
                minIndex = j;
            }
        }

        if (minIndex != i) {
            char temp = s[i];
            s[i] = s[minIndex];
            s[minIndex] = temp;
            return s;
        }
    }

    return s;
}

int main() {
    char s[101];
    scanf("%s", s);
    printf("%s\n", getMinString(s));
    return 0;
}

```

c++算法源码

```cpp
#include 
#include 
#include 

std::string getMinString(std::string s) {
    int n = s.length();

    for (int i = 0; i < n - 1; i++) {
        char minChar = s[i];
        int minIndex = i;

        for (int j = i + 1; j < n; j++) {
            if (s[j] < minChar) {
                minChar = s[j];
                minIndex = j;
            }
        }

        if (minIndex != i) {
            std::swap(s[i], s[minIndex]);
            return s;
        }
    }

    return s;
}

int main() {
    std::string s;
    std::cin >> s;
    std::cout << getMinString(s) << std::endl;
    return 0;
}

```

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/6079.html

(0)
LomuLomu
上一篇 2025 年 1 月 12 日 下午6:35
下一篇 2025 年 1 月 12 日 下午8:06

相关推荐

  • SpringMVC-08-拦截器

    1、拦截器概述 在SpringMVC框架中,处理器拦截器扮演着与Servlet过滤器(Filter)相似的角色,它们负责对处理器(Handler)进行预处理和后处理。开发者可以自定义拦截器以实现特定的业务需求。 过滤器与拦截器的主要区别: 过滤器 是servlet规范的一部分,适用于任何JavaWeb项目。 通过在url-pattern中配置/*,可以对所有…

    未分类 2024 年 12 月 24 日
    52400
  • 『玩转Streamlit』–查看K线的小工具

    在金融市场分析中,查看不同交易对的 K 线数据是一项基础且重要的工作。 今天,我们就来学习如何使用 Streamlit 构建一个简单的 K 线查看小工具,让你能够方便地查看不同交易对在不同时间范围内的 K 线数据。 1. 环境准备 首先,确保已经安装了必要的库。 除了 Streamlit 用于构建界面,还需要pandas 用于数据处理,plotly 用于绘制…

    2025 年 1 月 15 日
    77000
  • Java难绷知识02——抽象类中只能有或者必须有抽象方法吗以及有关抽象类的细节探讨

    Java难绷知识02——抽象类中只能有或者必须有抽象方法吗以及有关抽象类的细节探讨 标题长的像轻小说 首先回答标题抛出的问题——False 显然,有抽象方法的类是抽象类,但是,抽象类中只能有或者必须有抽象方法吗? 抽象类可以包含抽象方法,也可以包含具体方法 如果一个类包含至少一个抽象方法,用abstract关键字修饰,那么这个类必须被声明为抽象类。 抽象类除…

    未分类 2024 年 12 月 30 日
    53000
  • Java 技术前沿:大数据在智能医疗远程手术中的创新应用(215)

    ✨亲爱的技术爱好者们,诚挚欢迎您访问【青云科技博客】!在这个充满机遇的数字时代,我们致力于打造一个专业的技术交流平台。这里汇聚了前沿技术资讯和实用开发技巧,期待与您共同探讨技术奥秘,携手迈向智能未来!✨全网平台(微信公众号/CSDN/抖音/华为/支付宝/微博):青云科技一、加入【技术精英社群】快速加入通道1:[青云技术精英社群(最新)]快速加入通道2:[CS…

    2025 年 5 月 19 日
    79900
  • 数据库设计原则与方法

    — title: 数据库设计原则与方法 date: 2024/12/8 updated: 2024/12/8 author: cmdragon excerpt: 数据库设计是确保数据库高效、可靠运行的关键步骤。良好的数据库设计不仅能提高数据的存取速度,还能维护数据的完整性和一致性。在本节中,我们将探讨一些基本的数据库设计原则,以及常用的数据库设计方法,帮…

    未分类 2024 年 12 月 24 日
    52600

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信