知识点:字符串拼接
(1)字符串直接用+拼接
演示直接用+连接两个字符串
这样会有三个内存单元来存放字符串,浪费内存空间,建议采用StringBuffer(线程安全)或者StringBuilder(线程不安全)来实现字符串拼接。
(2)使用StringBuffer来拼接字符串
利用append()方法添加字符串,利用toString()得到缓冲区的字符串数据
(3)使用StringBuilder来拼接字符串
利用append()方法添加字符串,利用toString()得到缓冲区的字符串数据
(三)拓展练习
任务1、编程实现字符串大小写转换并倒序输出
例如:abThRx ⟹ \Longrightarrow ⟹ XrHtBA
任务2、编写一个简单的字符串加密和解密程序
自定义加密规则,比如a → \rightarrow →d, b → \rightarrow →e, c → \rightarrow →f…
任务六、输出指定要求的回文日期
1、2020 年春节期间,有一个特殊的日期引起了大家的注意:2020 年 2 月 2 日。因为如果将这个日期按“yyyymmdd”的格式写成一个8 位数是20200202,恰好是一个回文数。我们称这样的日期是回文日期(palindromic date)。有人表示20200202 是“千年一遇”的特殊日子。对此小明很不认同,因为不到 2 年之后就是下一个回文日期:20211202 即 2021年 12月2日。也有人表示 20200202 并不仅仅是一个回文日期,还是一个 ABABBABA 型的回文日期。对此小明也不认同,因为大约 100 年后就能遇到下一个 ABABBABA 型的回文日期:21211212即2121 年 12 月 12 日。算不上“千年一遇”,顶多算“千年两遇”。
2、给定一个 8 位数的日期,请你计算该日期之后下一个回文日期和下一个 ABABBABA 型回文日期各是哪一天。
3、输入描述:输入包含一个八位整数 N,表示日期。对于所有评测用例,10000101 ≤ N ≤ 89991231,保证 N 是一个合法日期的 8 位数
4、输出描述:输出两行,每行 1 个八位数。第一行表示下一个回文日期,第二行表示下一个 ABABBABA 型回文日期。
(一)编程实现
在net.guoxin.p03.t06包里创建PalindromicDate类
1、判断输入日期是否合法
创建静态方法isLegalDate(String strDate)
package net.guoxin.p03.t06;
/**
- 功能:输出指定要求的回文日期
- 作者:郭鑫
- 日期:2022年05月19日
/
public class PalindromicDate {
/*-
判断日期是否合法
-
@param strDate
-
@return true-合法,false-非法
*/
private static boolean isLegalDate(String strDate) {
int year, month, day;
year = Integer.parseInt(strDate.substrin
-