首页 > 其他分享 >字符串

字符串

时间:2024-10-29 13:45:27浏览次数:2  
标签:ch int 反转 right 字符串 left

字符串

1、反转字符串

题目链接:力扣
描述
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
示例

输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]

思路

使用两个指针分别指向数组的第一个和最后一个元素,两个指针同时向中间移动,依次交换数值

实现代码
方法一:

使用一个额外空间temp 来交换数值

class Solution {
    public void reverseString(char[] s) {
        int left = 0;
        int right = s.length-1;
        while(left < right ){
            char temp = s[left];
            s[left] = s[right];
            s[right] = temp;
            left++;
            right--;
        }
    }
}

方法二:

位运算 ^ 原地交换两个数 (a , b)
参与运算的两个值,如果两个相应bit位相同,则结果为0,否则为1。
即: 0^0 = 0, 1^0 = 1, 0^1 = 1, 1^1 = 0
任意一个变量a与其自身进行异或运算,结果为0,即a^a=0。
任意一个变量a与0进行异或运算,结果不变,即 a^0=a。
异或运算具有可结合性 异或运算具有可交换性

step1: a = a ^ b (完成后 a 变量的结果,代入step2)
step2: b = a ^ b (b = a ^ b = a ^ b ^ b = a ^ 0 = a)
经过前两步,a = a ^ b , b = a;
step3: a = a ^ b (a = a ^ b = a ^ b ^ a = a ^ a ^ b = 0 ^ b = b)

class Solution {
    public void reverseString(char[] s) {
        int left = 0;
        int right = s.length-1;
        while(left < right ){
            s[left]  ^= s[right];
            s[right] ^= s[left];
            s[left]  ^= s[right];
            left++;
            right--;
        }
    }
}

2、反转字符串 II

题目链接: 力扣
描述
给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。
如果剩余字符少于 k 个,则将剩余字符全部反转。
如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。
示例

输入:s = "abcdefg", k = 2
输出:"bacdfeg"

思路

使用 l 和 r 两个指针分别圈出每次需要翻转的范围,每次翻转完更新 l 和 r,同时注意范围 [l,r] 内不足 k 个的情况(将 r 与真实边界 n - 1取个 min)。

实现代码

class Solution {
    public String reverseStr(String s, int k) {
        char[] ch = s.toCharArray();
        for (int i = 0; i < ch.length-1; i += 2*k){
            int l = i;
            int r = Math.min(l+k-1, ch.length-1);
            while(l < r){
                ch[l] ^= ch[r];
                ch[r] ^= ch[l];
                ch[l] ^= ch[r];
                l++;
                r--;
            }
        }
        return String.valueOf(ch);
    }
}

3、字符串变形

题目链接:牛客
描述
对于一个长度为 n 字符串,我们需要对它做一些变形。
首先这个字符串中包含着一些空格,就像"Hello World"一样,然后我们要做的是把这个字符串中由空格隔开的单词反序,同时反转每个字符的大小写。
比如"Hello World"变形后就变成了"wORLD hELLO"。
输入描述:
给定一个字符串s以及它的长度n(1 ≤ n ≤ 10^6)
返回值描述:
请返回变形后的字符串。题目保证给定的字符串均由大小写字母和空格构成。

示例

输入:"This is a sample",16
返回值:"SAMPLE A IS tHIS"

思路

step 1:遍历字符串,反转每个字符的大小写。
step 2:第一次反转整个字符串,这样基本的单词逆序就有了,但是每个单词的字符也是逆的。
step 3:再次遍历字符串,以每个空间为界,将每个单词反转回正常。

实现代码

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * @param s string字符串 
     * @param n int整型 
     * @return string字符串
     */
    public String trans (String s, int n) {
        // write code here
        char[] ch = s.toCharArray();
        for(int i = 0; i < n; i++){
            if('A'<=ch[i]&&ch[i]<='Z') ch[i] = (char)(ch[i] - 'A' + 'a');
            else if('a'<=ch[i]&&ch[i]<='z') ch[i] = (char)(ch[i] - 'a' + 'A');
        }
        // 先整体翻转
        reverseArr(ch, 0, n-1);
        // 此时每个单词也逆序了,需要根据空格将每个单元重新反转回去
        for(int i=0; i<n; i++){
            if(ch[i] == ' ') continue;
            int j=i;
            while(j<n && ch[j]!=' ') j++;
            reverseArr(ch, i, j-1);
            i=j;
        }
        return String.valueOf(ch);
    }
    // 字符串数组翻转函数
    public void reverseArr(char[] arr, int i, int j){
        int l = i;
        int r = j;
        while(l < r){
            char temp = arr[l];
            arr[l] = arr[r];
            arr[r] = temp;
            l++;
            r--;
        }
    }
}

标签:ch,int,反转,right,字符串,left
From: https://www.cnblogs.com/dwhere/p/18512897

相关文章

  • Java学习第一天《String字符串的使用》
    1.获取字符最后一次出现的位置(函数返回值为int类型)                字符串的变量名.lastIndexOf(Stringstr);                               查找a最后出现的位置               System.out.print("请......
  • 百度二面算法:合法的括号字符串
    目录标题1.题目1.1示例2.利用栈求解2.1代码结构分析2.1.1代码优缺点1.题目给定一个字符串s,字符串s只包含以下三种字符:(,*,),请你判断s是不是一个合法的括号字符串。合法括号字符串有如下规则:左括号’(‘必须有对应的右括号’)’右括号’)‘必须有对应的左括号......
  • 模版字符串反引号
    JavaScript的模板字符串(templatestring)是一种字符串字面量,使用反引号(`)来标识。它可以包含动态的部分,即在运行时表达式的值可以嵌入其中。模板字符串中的表达式写在${}内。任何字符串都可以用反引号来创建,而且可以嵌入表达式。letname='Alice';letage=25;letgreeting=......
  • Python字典到JSON字符串的转换
    在Python中,字典是一种非常常见的数据结构。它可以轻松地转换为JSON字符串,从而实现了将Python对象序列化为JSON格式的目的。本文将详细介绍如何将Python字典转换为JSON字符串。1.Python字典的基本概念在Python中,字典是一种无序的键值对集合。每个键必须唯一且非空,而值可以是任何......
  • 【c++篇】:探索c++中的std::string类--掌握字符串处理的精髓
    ✨感谢您阅读本篇文章,文章内容是个人学习笔记的整理,如果哪里有误的话还请您指正噢✨✨个人主页:余辉zmh–CSDN博客✨文章所属专栏:c++篇–CSDN博客文章目录前言一.`std::string`对象的创建二.`std::string`对象的访问三.`std::string`对象的容量四.`std::string`对......
  • Go入门指南-7.6字符串、数组和切片的应用
    7.6.1从字符串生成字节切片假设s是一个字符串(本质上是一个字节数组),那么就可以直接通过c:=[]byte(s)来获取一个字节数组的切片c。另外,您还可以通过copy函数来达到相同的目的:copy(dst[]byte,srcstring)。同样的,还可以使用for-range来获得每个元素(Listing7.1......
  • SqlSugar 达梦数据库大数据量,长字符串添加,数据库为空
    SqlSugar实体添加数据时,发现字符串超过某个长度,在数据库中就空白,插入失败,原因如下:达梦Clob、Text类型用法版本需升级到5.1.4.92及以上版本//需在长字符串的属性中加入以下[SugarColumn(SqlParameterDbType=typeof(NClobPropertyConvert))]publicstringName{get;......
  • 字符串 (反转字符串、字符串变形) [Java]
    字符串1、反转字符串题目链接:力扣描述编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组s的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用O(1)的额外空间解决这一问题。示例输入:s=[“h”,“e”,“l”,“l”,“o”]......
  • 字符串划分方法汇总
    基本的split()方法split()按照指定分隔符将字符串分割成一个列表。如果不指定分隔符,默认使用空格。text="applebananaorange"result=text.split()#默认按空格分割,结果:['apple','banana','orange']​text="apple,banana,orange"result=text.spl......
  • 一文带你搞懂Java字符串
    1.API1.1API概述什么是API?API(ApplicationProgrammingInterface)是应用程序编程接口,它是一组工具、类、方法和规则,使不同的应用程序可以通过接口进行数据交互和操作。API的作用主要是:封装复杂性:提供简单的接口供开发者调用,不需要关心底层实现的细节。提高复用......