牛客网编程高频题26——NC103反转字符串

博客介绍了反转字符串的方法。要求程序接受字符串并输出其反转后的字符串,长度不超1000。给出三种方法:利用栈先进后出特性反转,但时间消耗大;倒叙赋值,新建字符串将目标字符串倒叙赋值;交换赋值,在原字符串上交换字符位置。

目录

反转字符串

描述

示例1

方法一:栈

方法二:倒叙赋值

方法三:交换赋值


 

反转字符串

描述

写出一个程序,接受一个字符串,然后输出该字符串反转后的字符串。(字符串长度不超过1000)

示例1

输入:

"abcd"

返回值:

"dcba"

 

方法一:栈

利用栈先进后出的特性进行反转

import java.util.*;

public class Solution {
    public String solve (String str) {
        // write code here
        Stack<Character> stack=new Stack();
        StringBuilder res=new StringBuilder();

        for (int i = 0; i < str.length(); i++) {
            stack.push(str.charAt(i));
        }

        while(!stack.isEmpty()){
            res.append(stack.pop());
        }
        return res.toString();
    }
}

该方法时间消耗较大,不建议采用, 

 

方法二:倒叙赋值

新建一个同样大小的字符串res,然后将目标字符串倒叙赋值到结果字符串中

import java.util.*;

public class Solution {
    public String solve (String str) {
        // write code here
        char[] res=str.toCharArray();
        int len=str.length();
        for (int i = 0; i < len; i++) {
            res[i]=str.charAt(len-1-i);
        }
        return new String(res);
    }
}

 

方法三:交换赋值

我们也可以不用创建新的字符串,在原字符串上进行交换,将第一个字符和最后一个字符交换位置,以此类推

import java.util.*;

public class Solution {
    public String solve (String str) {
        // write code here
        char[] res=str.toCharArray();
        int len=str.length();
        char temp;
        for (int i = 0; i < len/2; i++) {
            temp=res[i];
            res[i]=res[len-1-i];
            res[len-1-i]=temp;
        }
        return new String(res);
    }
}

 

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值