劍指Offer之Java算法習(xí)題精講字符串操作與數(shù)組及二叉搜索樹
題目一

?解法
class Solution {
public String reverseOnlyLetters(String s) {
char[] chars = s.toCharArray();
int left = 0;
int right = chars.length-1;
while(left<=right){
char tmp = 0;
if(chars[left]>='a'&&chars[left]<='z'||(chars[left]>='A'&&chars[left]<='Z')){
tmp = chars[left];
}else {
left++;
continue;
}
if(chars[right]>='a'&&chars[right]<='z'||(chars[right]>='A'&&chars[right]<='Z')){
chars[left] = chars[right];
chars[right] = tmp;
}else {
right--;
continue;
}
left++;
right--;
}
return new String(chars);
}
}
題目二

解法
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode() {}
* TreeNode(int val) { this.val = val; }
* TreeNode(int val, TreeNode left, TreeNode right) {
* this.val = val;
* this.left = left;
* this.right = right;
* }
* }
*/
class Solution {
public TreeNode increasingBST(TreeNode root) {
ArrayList<Integer> list = new ArrayList<Integer>();
method(root,list);
TreeNode ans = new TreeNode(-1);
TreeNode cur = ans;
for(int i:list){
TreeNode node = new TreeNode(i);
cur.right = node;
cur = cur.right;
}
return ans.right;
}
public void method(TreeNode root,List<Integer> list){
if(root==null) return;
method(root.left,list);
list.add(root.val);
method(root.right,list);
}
}
?題目三

解法
class Solution {
public int[] sortArrayByParity(int[] nums) {
int[] ans = new int[nums.length];
int left = 0;
int right = nums.length-1;
for(int i : nums){
if(i%2==0){
ans[left] = i;
left++;
}else{
ans[right] = i;
right--;
}
}
return ans;
}
}
class Solution {
public int[] sortArrayByParity(int[] nums) {
int left = 0;
int right = nums.length-1;
while(left<=right){
if(nums[left]%2==0){
left++;
continue;
}
if(nums[right]%2!=0){
right--;
continue;
}
if(nums[left]%2!=0&&nums[right]%2==0){
int tmp = nums[left];
nums[left] = nums[right];
nums[right] = tmp;
}
}
return nums;
}
}
?題目四

?解法
class Solution {
public boolean backspaceCompare(String s, String t) {
if(method(s).equals(method(t))) return true;
return false;
}
public static String method(String s){
int slow = 0;
char[] chars = s.toCharArray();
for (int i = 0; i < chars.length; i++) {
if(chars[i]=='#'){
chars[i] = 0;
slow = i;
while (true){
if(slow-1<0) break;
if (chars[slow-1]!=0){
chars[slow-1] = 0;
break;
}
slow--;
}
}
}
StringBuilder sb = new StringBuilder();
for(char i : chars){
if(i!=0) sb.append(i);
}
return sb.toString();
}
}
到此這篇關(guān)于劍指Offer之Java算法習(xí)題精講字符串操作與數(shù)組及二叉搜索樹的文章就介紹到這了,更多相關(guān)Java 字符串操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 劍指Offer之Java算法習(xí)題精講數(shù)組查找與字符串交集
- 劍指Offer之Java算法習(xí)題精講鏈表與字符串及數(shù)組
- 劍指Offer之Java算法習(xí)題精講數(shù)組與字符串題
- 劍指Offer之Java算法習(xí)題精講N叉樹的遍歷及數(shù)組與字符串
- 劍指Offer之Java算法習(xí)題精講數(shù)組與字符串
- 劍指Offer之Java算法習(xí)題精講數(shù)組與列表的查找及字符串轉(zhuǎn)換
- 關(guān)于java數(shù)組與字符串相互轉(zhuǎn)換的問題
- java 字符串轉(zhuǎn)化為字符數(shù)組的3種實(shí)現(xiàn)案例
- Java數(shù)組與字符串深入探索使用方法
相關(guān)文章
Jedis零基礎(chǔ)入門及操作Redis中的數(shù)據(jù)結(jié)構(gòu)詳解
Jedis 的 API 方法跟 Redis 的命令基本上完全一致,熟悉 Redis 的操作命令,自然就很容易使用 Jedis,因此官方也推薦 Java 使用 Jedis 來連接和操作 Redis2022-09-09
透過Spring源碼查看Bean的命名轉(zhuǎn)換規(guī)則圖文詳解
Java Bean是一種 Java 編程語言編寫的可重用軟件組件,包括符合一定規(guī)范的Java 類、屬性和方法,用于描述和處理應(yīng)用程序中的數(shù)據(jù)對象,下面這篇文章主要給大家介紹了關(guān)于透過Spring源碼查看Bean的命名轉(zhuǎn)換規(guī)則的相關(guān)資料,需要的朋友可以參考下2023-06-06
JAVA之讀取properties時(shí)路徑的注意問題
這篇文章主要介紹了JAVA之讀取properties時(shí)路徑的注意問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
Intellij idea遠(yuǎn)程debug連接tomcat實(shí)現(xiàn)單步調(diào)試
這篇文章主要介紹了Intellij idea遠(yuǎn)程debug連接tomcat實(shí)現(xiàn)單步調(diào)試,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05
使用Mybatis遇到的there is no getter異常
這篇文章主要介紹了使用Mybatis遇到的there is no getter異常,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09
JavaMail整合Spring實(shí)現(xiàn)郵件發(fā)送功能
這篇文章主要為大家詳細(xì)介紹了JavaMail整合Spring實(shí)現(xiàn)郵件發(fā)送功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
Java cglib為實(shí)體類(javabean)動態(tài)添加屬性方式
這篇文章主要介紹了Java cglib為實(shí)體類(javabean)動態(tài)添加屬性方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02

