倒置字符串——牛客笔试题day02

倒置字符串——牛客笔试题

题目描述

将一句话的单词进行倒置,标点不倒置。比如 I like beijing. 经过函数后变为:beijing. like I

输入描述:

每个测试输入包含1个测试用例: I like beijing. 输入用例长度不超过100

输出描述:

依次输出倒置之后的字符串,以空格分割

示例

输入:

I like beijing.

输出:

beijing. like I

核心思路

1. 先定义一个翻转函数reverse();
2. 整体转置;
3. 定义每一个单词的首下标为i,尾下标为j,如果尾下标j遇到空格就翻转i~(j-1)之间的字符,然后令i=j+1;继续往后循环…;
4. 当j=len时,直接翻转i~(j-1)之间的字符;
5. 需要注意的是:最后一个字符串翻转之后,还需要令i=j;目的是跳出while(i<len)的循环,如果没有这一步,将无法结束循环。

代码

import java.util.Scanner;

public class reverse_String {
    public static void reverse(char[] array, int start, int end) {
        while (start < end) {
            char temp = array[start];
            array[start] = array[end];
            array[end] = temp;
            start++;
            end--;
        }
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s = sc.nextLine();
        char[] ch = s.toCharArray();
        int len = s.length();
        //整体转置
        reverse(ch, 0, len - 1);
        int i = 0;
        while (i < len) {
            int j = i;
            while (j < len && ch[j] != ' ') {
                j++;
            }
            if (j < len) {
                reverse(ch, i, j - 1);
                i = j + 1;
            } else {
                reverse(ch, i, j - 1);
                //此时处理最后一个字符串,让i=j的目的是跳出while(i<len)的循环
                //如果没有这一步,无法结束循环
                i = j;
            }
        }
        String str = new String(ch);
        System.out.println(str);
    }
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值