zoukankan      html  css  js  c++  java
  • 字符移位

    来源: 牛客网 http://www.nowcoder.com/questionTerminal/7e8aa3f9873046d08899e0b44dac5e43

    小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。
    你能帮帮小Q吗?

    输入描述:


    输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.


    输出描述:


    对于每组数据,输出移位后的字符串。

    输入例子:

    AkleBiCeilD

    输出例子:

    kleieilABCD


    要求不能用额外的空间,那就只能就地移动了。遍历到一个大写字母,将其后的所有字符向前移动一步,然后将此大写字母放到末尾。重复以上过程。

    import java.util.*;
    
    
    public class Main {
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
            while (sc.hasNext()) {
                String s = sc.nextLine();
                char[] a = s.toCharArray();
                int n = s.length();
                int end = n;
                for (int i = 0; i < end; ++i) {
                    if (a[i] >= 'A' && a[i] <= 'Z') {
                        char tmp = a[i];
                        for (int j = i; j < n - 1; ++j)
                            a[j] = a[j + 1];
                        a[n - 1] = tmp;
                        end--;
                        i--;
                    }
                }
                for (int k = 0; k < n; ++k)
                    System.out.print(a[k]);
                System.out.println();
            }
        }
    }
    View Code
  • 相关阅读:
    Visual C++ 2010 SP1 x86&x64
    MVC拦截
    自定义HTTP消息拦截
    转mysql半主从同步
    mysql主从搭建之诡异事件
    snapshot相关
    分布式系统唯一ID生成方案汇总
    mysql监控利器mysqlmtop部署安装
    mysql日常运维
    MySQL索引背后的数据结构及算法原理
  • 原文地址:https://www.cnblogs.com/duanguyuan/p/5675179.html
Copyright © 2011-2022 走看看