博客
关于我
【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/

    你可能感兴趣的文章
    oracle常见操作
    查看>>
    oracle常见错误
    查看>>
    Oracle并行
    查看>>
    oracle数据库 添加定时器
    查看>>
    Oracle数据库入门——初级系列教程
    查看>>
    oracle数据库包package小例子
    查看>>
    UBUNTU 添加删除用户
    查看>>
    Oracle数据库备份与还原
    查看>>
    Ubuntu Seata开机自启动服务
    查看>>
    uart 驱动架构
    查看>>
    Oracle数据库学习(三)
    查看>>
    Oracle数据库安装成功后,忘记解锁账户和设置密码
    查看>>
    TypeError: create_purple() 接受 0 个位置参数,但给出了 2 个
    查看>>
    Oracle数据库异常--- oracle_10g_登录em后,提示java.lang.Exception_Exception_in_sending_Request__null或Connection
    查看>>
    Oracle数据库异常---OracleDBConsoleorcl无法启动
    查看>>
    oracle数据库异常---SP2-1503: 无法初始化 Oracle 调用界面 SP2-1503: 无法初始化 Oracle 问题的解决办法
    查看>>
    Oracle数据库性能调优
    查看>>
    oracle数据库核心笔记
    查看>>
    oracle数据库笔记---oracleweb视图使用流程,及plsql安装
    查看>>
    oracle数据库笔记---pl/sql的基础使用方法
    查看>>