1、如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串。字母和数字都属于字母数字字符。给你一个字符串s,如果它是回文串,返回 true:否则,返回false。
package com.ctgu.Test;
import java.util.Scanner;
public class Solution {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String s = scanner.next();
System.out.println(function(s));
}
public static boolean function(String s){
if(s.isEmpty()){
return false;
}
String temp = s.replaceAll("[^a-zA-Z0-9]","").toLowerCase();//保存大写转换成小写字母、并采用正则表达式去除非字母数字的部分。
int left = 0;
int right = temp.length()-1;
//这两个变量分别指向字符串的起始位置和结束位置。
while (left < right){
if(temp.charAt(left) != temp.charAt(right)){
return false;
}
left ++;
right --;
}
return true;
}
}
2、给你两个字符串word1和word2。请你从 word1开始,通过交替添加字母来合并字符串。如果一个字符串比另一个字符串长, 就将多出来的字母追加到合并后字符串的末尾。 返回合并后的字符串。
package com.ctgu.Test;
import java.util.Scanner;
public class Concatenate {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String word1 = scanner.next();
String word2 = scanner.next();
System.out.println(montage(word1,word2));
}
public static String montage(String word1,String word2){
StringBuilder builder = new StringBuilder();//保存最终结果。
if(word1 == null || word2 == null){
return null;
}
int left=0;//记录word1的下标。
int right=0;//记录word2的下标。
while(left < word1.length() || right < word2.length()){
if(left < word1.length()){
builder.append(word1.charAt(left));
left++;
}
if(right < word2.length()){
builder.append(word2.charAt(right));
right++;
}
}
return builder.toString();
}
}
3、如何判断距离今天100天之后是星期几?
package com.ctgu.Test;
import java.time.DayOfWeek;
import java.time.LocalDate;
public class Week {
public static void main(String[] args) {
LocalDate today = LocalDate.of( 2023,12,13);//当前日期
LocalDate dayAfter100Days = today.plusDays( 100);//一百天之后的日期
DayOfWeek dayOfWeek = dayAfter100Days.getDayOfWeek();//获取星期几
System.out.println("Today is:"+today.getDayOfWeek());
System.out.println("After 100 days, it will be:"+dayOfWeek);
}
}