博客
关于我
剑指offer之面试题58:翻转字符串
阅读量:324 次
发布时间:2019-03-04

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

面试题58:翻转字符串

题目一:翻转单词顺序

输入一个英文句子,翻转句子中单词的顺序,但单词内的顺序不变。为简单起见,标点符号和普通字符一样处理。例如,输入字符串"I am a student.",则输出"student. a am I"。

思路:

  1. 按照空格分割字符串。
  2. 将得到的字符串数组倒序输出。

代码实现:

package Question58;public class T01 {       public static void main(String[] args) {           String str = "  hello world!  ";        System.out.println(solve(str));    }    public static String solve(String str) {           String[] strs = str.trim().split(" ");        StringBuilder sb = new StringBuilder();        for(int i = strs.length - 1; i >= 0; i--) {               sb.append(strs[i]);            if(i != 0) sb.append(" ");        }        return sb.toString();    }}

题目二:左旋转字符串

字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。

思路:

  1. 旋转整个字符串
  2. 旋转后两位
  3. 旋转前面5位。

代码实现:

package Question58;public class T02 {       public static void main(String[] args) {           System.out.println(solve("abcdefg", 2));    }    public static String solve(String str, int n) {           String s = "";        for(int i = n; i < n + str.length(); i++) {               s += str.charAt(i % str.length());        }        return s;    }}

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

你可能感兴趣的文章
mqtt broker服务端
查看>>
MQTT 保留消息
查看>>
MQTT 持久会话与 Clean Session 详解
查看>>
MQTT工作笔记0007---剩余长度
查看>>
MQTT工作笔记0009---订阅主题和订阅确认
查看>>
Mqtt搭建代理服务器进行通信-浅析
查看>>
MS Edge浏览器“STATUS_INVALID_IMAGE_HASH“兼容性问题
查看>>
ms sql server 2008 sp2更新异常
查看>>
MS UC 2013-0-Prepare Tool
查看>>
MSBuild 教程(2)
查看>>
msbuild发布web应用程序
查看>>
MSB与LSB
查看>>
MSCRM调用外部JS文件
查看>>
MSCRM调用外部JS文件
查看>>
MSEdgeDriver (Chromium) 不适用于版本 >= 79.0.313 (Canary)
查看>>
MsEdgeTTS开源项目使用教程
查看>>
msf
查看>>
MSSQL数据库查询优化(一)
查看>>
MSSQL数据库迁移到Oracle(二)
查看>>
MSSQL日期格式转换函数(使用CONVERT)
查看>>