java编程思想第四版第十三章字符串 习题
- fas
- 第二题
package net.mindview.strings; import java.util.ArrayList;
import java.util.List; /**
* 无限循环
*/
public class InfiniteRecursion {
public InfiniteRecursion(){ }
@Override
public String toString() {
return " InfiniteRecursion address" + super.toString() + "\n";
}
public static void main(String[] args) {
List<InfiniteRecursion> list = new ArrayList<InfiniteRecursion>();
for(int i=; i<; i++){
list.add(new InfiniteRecursion());
}
System.out.println(list);
}
} - fa
- 第四题
package net.mindview.strings; import java.util.Formatter; public class Receipt {
private double total = ;
private Formatter f = new Formatter(System.out);
public final int ITEM_WIDTH = ;
public final int QTY_WIDTH = ;
public final int PRICE_WIDTH = ;
public final int PRICISION_FLOAT_WIDHT = ;
public final int PRICISION_String_WIDHT = ;
public final String TITLE_FORMAT = "%-" + ITEM_WIDTH + "s %" + QTY_WIDTH
+ "s %" + PRICE_WIDTH + "s\n";
public final String PRICE_FORMAT = "%-" + ITEM_WIDTH + "."
+ PRICISION_String_WIDHT + "s %" + QTY_WIDTH + "d %" + PRICE_WIDTH
+ "." + PRICISION_FLOAT_WIDHT + "f\n";
public final String TOTAL_FORMAT = "%-" + ITEM_WIDTH + "s %" + QTY_WIDTH
+ "s %" + PRICE_WIDTH + "." + PRICISION_FLOAT_WIDHT + "f\n"; //打印标题
public void printTitle(){
/*
* 含义: 格式化字符串串以%开头
* -: 表示左对齐
* 15: 15表示宽度
* s:表示数据的类型是String
* .2f:表示浮点数保留的小数位数
* .15s:表示字符串的长度最多15个字符
*/
f.format(TITLE_FORMAT, "Item", "Qty", "Price");
f.format(TITLE_FORMAT, "----", "---", "-----");
} //正文的内容
public void print(String name, int qty, double price){
f.format(PRICE_FORMAT, name, qty, price);
total += price;
} //总价
public void printTotal(){
f.format(TOTAL_FORMAT, "Tax", "", total*0.06);
f.format(TITLE_FORMAT, "", "", "-----");
f.format(TOTAL_FORMAT, "Total", "", total*1.06);
} public static void main(String[] args) {
Receipt receipt = new Receipt();
receipt.printTitle();
receipt.print("Jack`s Magic Beans", , 4.25);
receipt.print("Princess Peas", , 5.1);
receipt.print("Three Bears Porridge", , 14.29);
receipt.printTotal();
} }运行结果:
Item Qty Price
---- --- -----
Jack`s Magic Be 4.25
Princess Peas 5.10
Three Bears Por 14.29
Tax 1.42
-----
Total 25.06 - 第五题
package net.mindview.strings; import java.util.Formatter; public class Receipt {
private double total = ;
private Formatter f = new Formatter(System.out);
public final int ITEM_WIDTH = ;
public final int QTY_WIDTH = ;
public final int PRICE_WIDTH = ;
public final int PRICISION_FLOAT_WIDHT = ;
public final int PRICISION_String_WIDHT = ;
public final String TITLE_FORMAT = "%-" + ITEM_WIDTH + "s %" + QTY_WIDTH
+ "s %" + PRICE_WIDTH + "s\n";
public final String PRICE_FORMAT = "%-" + ITEM_WIDTH + "."
+ PRICISION_String_WIDHT + "s %" + QTY_WIDTH + "d %" + PRICE_WIDTH
+ "." + PRICISION_FLOAT_WIDHT + "f\n";
public final String TOTAL_FORMAT = "%-" + ITEM_WIDTH + "s %" + QTY_WIDTH
+ "s %" + PRICE_WIDTH + "." + PRICISION_FLOAT_WIDHT + "f\n"; //打印标题
public void printTitle(){
/*
* 含义: 格式化字符串串以%开头
* -: 表示左对齐
* 15: 15表示宽度
* s:表示数据的类型是String
* .2f:表示浮点数保留的小数位数
* .15s:表示字符串的长度最多15个字符
*/
f.format(TITLE_FORMAT, "Item", "Qty", "Price");
f.format(TITLE_FORMAT, "----", "---", "-----");
} //正文的内容
public void print(String name, int qty, double price){
f.format(PRICE_FORMAT, name, qty, price);
total += price;
} //总价
public void printTotal(){
f.format(TOTAL_FORMAT, "Tax", "", total*0.06);
f.format(TITLE_FORMAT, "", "", "-----");
f.format(TOTAL_FORMAT, "Total", "", total*1.06);
} public static void main(String[] args) {
Receipt receipt = new Receipt();
receipt.printTitle();
receipt.print("Jack`s Magic Beans", , 4.25);
receipt.print("Princess Peas", , 5.1);
receipt.print("Three Bears Porridge", , 14.29);
receipt.printTotal();
} }运行结果:
Item Qty Price
---- --- -----
Jack`s Magic Be 4.25
Princess Peas 5.10
Three Bears Por 14.29
Tax 1.42
-----
Total 25.06 - afd
- 第七题:
package net.mindview.strings.test7; public class Test7 { public static void main(String[] args) {
//两种写法都可以
String regex = "^[A-Z].*\\.$";
String regex1 = "\\p{Upper}.*\\.$";
String str = "D.";
String str1 = "Dfasdfasfasfdasfdasfasfasdf.";
String str2 = "Dfasdfasfasfdasfdasfasfasdf.E";
System.out.println(str.matches(regex));
System.out.println(str1.matches(regex));
System.out.println(str2.matches(regex));
System.out.println(str.matches(regex1));
System.out.println(str1.matches(regex1));
System.out.println(str2.matches(regex1));
}
}运行结果:
true
true
false
true
true
false - 第八题
package net.mindview.strings; import java.util.Arrays; public class Splitting { public static String knights = "Then, when you have found the shrubbery, you must cut down the mightiest tree in the forest... with... a herring!"; public static void split(String regex){
System.out.println(Arrays.toString(knights.split(regex)));
}
public static void main(String[] args) {
//表示的时按照空格分割字符串
//运行结果:[Then,, when, you, have, found, the, shrubbery,, you, must, cut, down, the, mightiest, tree, in, the, forest..., with..., a, herring!]
split(" "); //表示按照非单次字符分割字符串--这里的非单次字符是空格和,
//运行结果:[Then, when, you, have, found, the, shrubbery, you, must, cut, down, the, mightiest, tree, in, the, forest, with, a, herring]
split("\\W+");
//这个表示:费单次字符之前带n的地方进行分割字符串 这里的分割符是n空格和n,
//运行结果:[The, whe, you have found the shrubbery, you must cut dow, the mightiest tree i, the forest... with... a herring!]
split("n\\W+");
} }package net.mindview.strings.test8; import net.mindview.strings.Splitting; public class Test8 { public static void main(String[] args) {
String regex = "the|you";
Splitting.split(regex);
}
} - 第九题
package net.mindview.strings.test9; import net.mindview.strings.Splitting; public class Test9 {
public static void main(String[] args) {
String regex = "A|E|I|O|U|a|e|i|o|u";
//通过嵌入式标志表达式 (?i) 也可以启用不区分大小写的匹配。
String regex1 = "(?i)a|e|i|o|u";
//[abc] 表示a或b或c
String regex2 = "(?i)[aeiou]";
System.out.println(Splitting.knights.replaceAll(regex, "_"));
System.out.println(Splitting.knights.replaceAll(regex1, "_"));
System.out.println(Splitting.knights.replaceAll(regex2, "_"));
}
} - 第十题
package net.mindview.strings.test10; import java.util.regex.Matcher;
import java.util.regex.Pattern; public class Test10 {
public static void main(String[] args) {
String str = "Java now has regular expressions"; for(String arg: args){
Pattern p = Pattern.compile(arg);
Matcher m = p.matcher(str);
while(m.find()){
System.out.println("Match \"" + m.group() +"\" at positions " + m.start() + "-" + (m.end()-) );
}
System.out.println("\n");
} }
}输入参数:
^Java
\Breg.*
n.w\s+h(a|i)s
s?
s*
s+
s{}
s{}.
s{,}输出结果
Match "Java" at positions - Match "now has" at positions - Match "" at positions --
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "s" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "s" at positions -
Match "s" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "s" at positions -
Match "" at positions - Match "s" at positions -
Match "ss" at positions -
Match "s" at positions - Match "s " at positions -
Match "ss" at positions - Match "" at positions --
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "s" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "ss" at positions -
Match "" at positions -
Match "" at positions -
Match "" at positions -
Match "s" at positions -
Match "" at positions - - 第十一题
package net.mindview.strings.test11; import java.util.regex.Matcher;
import java.util.regex.Pattern; public class Test11 {
public static void main(String[] args) {
Pattern p = Pattern.compile("(?i)((^[aeiou])|(\\s+[aeiou]))\\w+?[aeiou]\\b");
Matcher m = p.matcher("Arline ate eight apples and " +
"one orange while Anita hadn't any"); while(m.find()){
System.out.println("Match \"" + m.group() +
"\" at positions " + m.start() + "-" +
(m.end() - ));
}
}
}运行结果:
Match "Arline" at positions -
Match " ate" at positions -
Match " one" at positions -
Match " orange" at positions -
Match " Anita" at positions - - sfa
- f
- a
- fda
- sdf
- af
- a
- fd
- af
- as
- fd
- asfd
- af
- da
- f
- df
- as
- fa
- sf
- asf
- a
- sf
- af
- asf
java编程思想第四版第十三章字符串 习题的更多相关文章
- java编程思想第四版第十三章字符串 总结
1. String和StringBulider的使用 通过书中介绍, 我们得知如下结论: 当使用+连接符将字符串进行拼接的时候, 编译器会进行自动优化为使用StringBuilder连接字符串. 当在 ...
- java编程思想第四版第三章要点习题
使用"简短的" 和正常的 打印语句来编写一个程序 package net.mindview.util; public class Print { /** * 不带有回车 * @pa ...
- java编程思想第四版第十一章习题
第一题 package net.mindview.holding.test1; import java.util.ArrayList; import java.util.List; /** * 沙鼠 ...
- Java编程思想第四版*第七章*个人练习
欢迎加群:239063848 成团的笔记:该组仅用于技术共享和交流,问题和答案公布 潘基聊天.禁止广告.禁止招聘-- 练习1:(2)创建一个简单的类.第二个类中,将一个引用定义为第一个类的对象.运用惰 ...
- java编程思想第四版第六章习题
(略) (略) 创建两个包:debug和debugoff,他们都包含一个相同的类,该类有一个debug()方法,第一个版本显示发送给控制台的String参数,而第二版本什么也不做,使用静态import ...
- java编程思想第四版第六章总结
1. 代码重构 为什么f要代码重构 第一次代码不一定是完美的, 总会发现更优雅的写法. 代码重构需要考虑的问题 类库的修改不会破坏客户端程序员的代码. 源程序方便扩展和优化 2. 包 创建一个独一无二 ...
- java编程思想第四版第五章习题
创建一个类, 它包含一个未初始化的String引用.验证该引用被Java初始化成了null package net.mindview.initialization; public class Test ...
- java编程思想 第四版 第六章 个人练习
欢迎加群:239063848 进群须知:本群仅用于技术分享与交流.问题公布与解答 禁止闲聊.非诚勿扰 练习1:(1)在某个包中创建一个类,在这个类所处的包的外部创建该类的一个实例. import mi ...
- java编程思想第四版第十一章总结
1. 容器类被分为两类:Collection和Map Collection是一个接口:包括: List接口: ArrayList:按照被插入顺序保存元素, 查询快, 增删改慢 LinkedList:按 ...
随机推荐
- msf后门之persistence
在获取得了meterpreter shell后 使用Persistence建立持续性后门 run persistence -h meterpreter > run persistence -h ...
- C#方法的定义、调用与调试
本节内容 1.方法的由来: 2.方法的定义与调用: 3.构造器(一种特殊的方法): 4.方法的重载(Override): 5.如何对方法进行debug: 6.方法的调用与栈* *推荐书目:CLR vi ...
- spring boot打印sql语句-mybatis
spring boot打印sql语句-mybatis 概述 当自己编写的程序出现了BUG等等,找了很久 调试运行了几遍到mapper层也进去调试进了源码,非常麻烦 我就想打印出sql语句,好进行解决B ...
- 【译】Source Maps浅析
Time:2019/10/27~2019/10/29 Link: 原文链接 译文开始: 对网站进行性能优化对一个最容易的方法就是把JS和CSS进行打包压缩.但是当你需要调试这些压缩文件中的代码的时候, ...
- 模块基础 day15
目录 模块的四种形式 内置模块 pip安装的模块 自定义模块 包(模块) import和from···import 循环导入 模块的搜索路径 python文件的两种用途 模块的四种形式 模块就是一系列 ...
- 字符编码 + python2和python3的编码区别(day08整理)
目录 昨日回顾 二十三.元组内置方法 二十四.散列表 二十五.字典内置方法 二十六.集合内置方法 二十七.深浅拷贝 拷贝 浅拷贝 深拷贝 今日内容 二十八.字符编码 1.文本编辑器存储信息的过程 2. ...
- GO基础之List
一.List定义 概述1.list是一种非连续存储的容器,由多个节点组成,节点通过一些变量记录彼此之间的关系.list有多种实现方法,如单向链表.双向链表等.2.Go语言中list的实现原理是双向链表 ...
- C语言存储类别和链接
目录 C语言存储类别和链接 存储类别 存储期 五种存储类别 C语言存储类别和链接 最近详细的复习C语言,看到存储类别的时候总感觉一些概念模糊不清,现在认真的梳理一下.C语言的优势之一能够让程序员恰 ...
- 无法打开msvcrtd.lib
- 【POJ3744】Scout YYF I
Description YYF是一个英勇的侦查员.现在他正在执行打入到敌方内部的危险任务.在解决了一系列的险情后,YYF到达了敌方著名的"地雷路"起始点.这条路非常长,上面被精心排 ...