去除重复Java_去除重复字母(Java实现)

题目 去除重复字母

给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。需保证 返回结果的字典序最小(要求不能打乱其他字符的相对位置)。

示例1

输入:s = "bcabc"

输出:"abc"

示例2

输入:s = "cbacdcbc"

输出:"acdb"

数据范围

1 <= s.length <= 104

s 由小写英文字母组成

代码

/*

* 算法思想

* 当字典序最小时,即12341 12351 主要看4,5的位置

* 用栈存储,当栈空时直接入栈

* 栈不为空时,

* 若栈中包含当前要入栈的元素直接跳到下一次循环。(结果字符串每个字符只含有一次)

* 若当前要入栈的字母比栈顶字母大时,考虑是否栈顶元素出栈

* 若栈顶元素在剩余字符串中仍然存在,那么就可以出栈,出栈后继续判断新的栈顶元素是否出栈。

*/

import java.util.Stack;

public class RemoveDuplicateLetters {

public static String removeDuplicateLetters(String s){

Stack stack = new Stack();

for (int i = 0; i < s.length(); i++) {

char c=s.charAt(i);

if(stack.contains(c))

continue;

while(!stack.isEmpty() && stack.peek()>c && s.indexOf(stack.peek(),i)!=-1)

stack.pop();

stack.push(c);

}

char chars[]=new char[stack.size()];

for (int i = 0; i < stack.size(); i++) {

chars[i]=stack.get(i);

}

return new String(chars);

}

public static void main(String[] args) {

String string = "bbcaac";

System.out.println(removeDuplicateLetters(string));

}

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于将汉字转换为拼音,Java中可以使用第三方库pinyin4j来实现。下面是一个将汉字转换为拼音首字母大写字母Java代码示例: ```java import net.sourceforge.pinyin4j.PinyinHelper; import java.util.regex.Matcher; import java.util.regex.Pattern; public class PinyinUtil { /** * 将汉字转换为拼音首字母大写字母 * * @param chinese 汉字字符串 * @return 拼音首字母大写字符串 */ public static String toFirstUpperCase(String chinese) { StringBuilder sb = new StringBuilder(); // 将汉字转换为拼音数组 String[] pinyinArray = PinyinHelper.toHanyuPinyinStringArray(chinese); if (pinyinArray != null && pinyinArray.length > 0) { for (String pinyin : pinyinArray) { // 提取每个拼音的首字母 String firstChar = pinyin.substring(0, 1); sb.append(firstChar.toUpperCase()); } } return sb.toString(); } /** * 将汉字转换为拼音字符串 * * @param chinese 汉字字符串 * @return 拼音字符串 */ public static String toPinyinString(String chinese) { StringBuilder sb = new StringBuilder(); // 将汉字转换为拼音数组 String[] pinyinArray = PinyinHelper.toHanyuPinyinStringArray(chinese); if (pinyinArray != null && pinyinArray.length > 0) { for (String pinyin : pinyinArray) { sb.append(pinyin); } } // 去除字母字符 Pattern pattern = Pattern.compile("[^a-zA-Z]"); Matcher matcher = pattern.matcher(sb.toString()); return matcher.replaceAll(""); } } ``` 使用示例: ```java public static void main(String[] args) { String chinese = "中国人"; String pinyin = PinyinUtil.toPinyinString(chinese); String firstChar = PinyinUtil.toFirstUpperCase(chinese); System.out.println(pinyin); // zhongguoren System.out.println(firstChar); // ZGR } ``` 希望能够帮到您!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值