当前位置:网站首页>字符串——344.反转字符串
字符串——344.反转字符串
2022-07-24 11:23:00 【向着百万年薪努力的小赵】
1 题目描述
- 反转字符串
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
2 题目示例
示例 1:
输入:s = [“h”,“e”,“l”,“l”,“o”]
输出:[“o”,“l”,“l”,“e”,“h”]
示例 2:
输入:s = [“H”,“a”,“n”,“n”,“a”,“h”]
输出:[“h”,“a”,“n”,“n”,“a”,“H”]
3 题目提示
1 <= s.length <= 105
s[i] 都是 ASCII 码表中的可打印字符
4 思路
对于长度为N的待被反转的字符数组,我们可以观察反转前后下标的变化,假设反转前字符数组为s[o] s[1] s[2] … sLN- 1],那么反转后字符数组为s[N - 1] s[N - 2] …s[o]。比较反转前后下标变化很容易得出s[i]的字符与s[N - 1 - i]的字符发生了交换的规律,因此我们可以得出如下双指针的解法:
- 将1eft指向字符数组首元素,right指向字符数组尾元素。
- 当1eft < right :
- 交换s[1eft]和s[right] ;
- left指针右移一位,即1eft = left + 1 ;
- right指针左移一位,即right = right - 1。
- 当1eft >= right ,反转结束,返回字符数组即可。

复杂度分析
时间复杂度:O(N)O(N),其中 NN 为字符数组的长度。一共执行了 N/2N/2 次的交换。
空间复杂度:O(1)O(1)。只使用了常数空间来存放若干变量。
5 我的答案
class Solution {
public void reverseString(char[] s) {
int n = s.length;
for (int left = 0, right = n - 1; left < right; ++left, --right) {
char tmp = s[left];
s[left] = s[right];
s[right] = tmp;
}
}
}
边栏推荐
- 【Golang】golang中map元素的删除和清空
- Publish local images to Alibaba cloud
- Jmeter-Runtime控制器
- 这个应该是全网最全的接口测试工具之postman
- 【Golang】golang实现sha256加密函数
- Simply understand MODBUS function code and partition
- Kubernetes Foundation
- MySQL queries tables and fields according to comments
- 周末和技术大咖们聚餐,聊到了软件测试行业的“金九银十”高峰【内卷之势已然形成】
- Redis cluster setup
猜你喜欢

Robot Framework官方教程(一)入门

Why can't memset initialize array elements to 1?

Zynq TTC usage

Installing Oracle Xe with Linux

视频回放 | 如何成为一名优秀的地学和生态学领域的国际期刊审稿人?

This is the right way for developers to open artifact!

E2PROM read / write (xiicps) on PS side of zcu102 board

如何从功能测试到自动化测试?

RRPN:Arbitrary-Oriented Scene Text Detection via Rotation Proposals

Only "a little bit", why do developers look up to you?
随机推荐
Lanqiao cup provincial training camp - stack and recursion
ctfshow ThinkPHP专题 1
Stack Title: basic calculator II
tcp 服务端接收数据处理思路梳理,以及select: Invalid argument报错 笔记
Logic of automatic reasoning 06 -- predicate calculus
Introduction to kubernetes Basics
运算放大器 —— 快速复苏笔记[壹](参数篇)
[golang] golang implements the string interception function substr
简单使用 MySQL 索引
Xilinx FPGA Microblaze AXI_ IIC usage and experience
Docker builds MySQL master-slave replication
[golang] golang implements MD5 encryption function
Blue Bridge Cup - binary conversion exercise
High speed ADC test experience
性能测试总结(一)---基础理论篇
RRPN:Arbitrary-Oriented Scene Text Detection via Rotation Proposals
Sorting out the ideas of data processing received by TCP server, and the note of select: invalid argument error
Semaphore详解
Neo4j installation tutorial
【C】 Recursive and non recursive writing of binary tree traversal