博客
关于我
【java】1370. 上升下降字符串-----了解字符串,让算法不再困难!!!
阅读量:359 次
发布时间:2019-03-04

本文共 5373 字,大约阅读时间需要 17 分钟。

为了根据给定的算法重新构造字符串,我们可以将字符串分为两轮,每轮包括两部分:选最小字符和选最大字符。每一步中,选择符合条件的字符并添加到结果字符串中,直到所有字符都被选完。

以下是实现该算法的代码:

import java.util.ArrayList;import java.util.List;public class SortString {    public static String sortString(String s) {        List
chars = new ArrayList<>(); for (char c : s.toCharArray()) { chars.add(c); } StringBuilder result = new StringBuilder(); Character lastMinChar = null; Character lastMaxChar = null; while (!chars.isEmpty()) { // 选最小字符的部分 if (lastMinChar == null) { // 找到最小的字符 char minChar = Character.maxChar; for (char c : chars) { if (c < minChar) { minChar = c; } } if (minChar == Character.maxChar) { break; } for (int i = 0; i < chars.size(); i++) { if (chars.get(i) == minChar) { result.append(minChar); lastMinChar = minChar; chars.remove(i); // 检查是否有更大的字符 boolean hasLarger = false; for (char c : chars) { if (c > minChar) { hasLarger = true; break; } } if (!hasLarger) { break; } break; } } } else { // 找到比lastMinChar大的最小字符 char minChar = Character.maxChar; for (char c : chars) { if (c > lastMinChar && c < minChar) { minChar = c; } } if (minChar == Character.maxChar) { break; } for (int i = 0; i < chars.size(); i++) { if (chars.get(i) == minChar) { result.append(minChar); lastMinChar = minChar; chars.remove(i); // 检查是否有更大的字符 boolean hasLarger = false; for (char c : chars) { if (c > minChar) { hasLarger = true; break; } } if (!hasLarger) { break; } break; } } } // 处理选最大字符的部分 if (lastMaxChar == null) { // 找到最大的字符 char maxChar = Character.minChar; for (char c : chars) { if (c > maxChar) { maxChar = c; } } if (maxChar == Character.minChar) { break; } for (int i = 0; i < chars.size(); i++) { if (chars.get(i) == maxChar) { result.append(maxChar); lastMaxChar = maxChar; chars.remove(i); // 检查是否有更小的字符 boolean hasSmaller = false; for (char c : chars) { if (c < maxChar) { hasSmaller = true; break; } } if (!hasSmaller) { break; } break; } } } else { // 找到比lastMaxChar小的最大字符 char maxChar = Character.minChar; for (char c : chars) { if (c < lastMaxChar && c > maxChar) { maxChar = c; } } if (maxChar == Character.minChar) { break; } for (int i = 0; i < chars.size(); i++) { if (chars.get(i) == maxChar) { result.append(maxChar); lastMaxChar = maxChar; chars.remove(i); // 检查是否有更小的字符 boolean hasSmaller = false; for (char c : chars) { if (c < maxChar) { hasSmaller = true; break; } } if (!hasSmaller) { break; } break; } } } // 检查是否所有字符都被选完 if (chars.isEmpty()) { break; } } return result.toString(); }}

代码解释

  • 初始化:将输入字符串转换为字符列表,便于逐个操作。
  • 循环处理:直到字符列表为空为止,分为两部分处理:选最小字符和选最大字符。
  • 选最小字符:首先找到当前最小字符,并添加到结果字符串中。然后检查是否有比当前字符大的字符,继续循环直到无法再选为止。
  • 选最大字符:类似地,找到当前最大字符并添加到结果字符串中,然后检查是否有比当前字符小的字符,继续循环直到无法再选为止。
  • 重复:整个过程重复,直到所有字符都被选完。
  • 这个算法确保每一步都严格按照题目要求,先选最小字符,再选比上一个大的最小字符,然后选最大字符,再选比上一个小的最大字符,直到所有字符都被选完。

    转载地址:http://ktmq.baihongyu.com/

    你可能感兴趣的文章
    Okhttp3添加拦截器后,报错,java.io.IOException: unexpected end of stream on okhttp3.Address
    查看>>
    Okhttp拦截器
    查看>>
    OkHttp源码解析(构建者模式、责任链模式、主线流程)
    查看>>
    OkHttp透明压缩,收获性能10倍,外加故障一枚
    查看>>
    OKR为什么到今天才突然火了?
    查看>>
    ol3 Demo2 ----地图搜索功能
    查看>>
    OLAP、OLTP的介绍和比较
    查看>>
    OLAP在大数据时代的挑战
    查看>>
    Vue.js 学习总结(12)—— 微前端实践思考与总结
    查看>>
    oldboy.16课
    查看>>
    OLEDB IMEX行数限制的问题
    查看>>
    ollama 如何删除本地模型文件?
    查看>>
    ollama-python-Python快速部署Llama 3等大型语言模型最简单方法
    查看>>
    Ollama怎么启动.gguf 大模型
    查看>>
    ollama本地部署DeepSeek(Window图文说明)
    查看>>
    ollama运行多模态模型如何进行api测试?
    查看>>
    OMG,此神器可一次定一周的外卖
    查看>>
    Omi 多端开发之 - omip 适配 h5 原理揭秘
    查看>>
    On Error GOTO的好处
    查看>>
    onclick事件的基本操作
    查看>>