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:按 ...
随机推荐
- burp插件之xssValidator
0x01 安装环境 Phantomjs 下载:http://phantomjs.org/download.html 下载后配置环境变量,把bin目录下的这个exe加入环境变量 xssValidator ...
- Intel Ivy Bridge Microarchitecture Events
This is a list of all Intel Ivy Bridge Microarchitecture performance counter event types. Please see ...
- 特征真的越多越好吗?从特征工程角度看“garbage in,garbage out”
1. 从朴素贝叶斯在医疗诊断中的迷思说起 这个模型最早被应用于医疗诊断,其中,类变量的不同值用于表示患者可能患的不同疾病.证据变量用于表示不同症状.化验结果等.在简单的疾病诊断上,朴素贝叶斯模型确实发 ...
- 关于vue使用的一些小经验
这一年来说,vue的势头很猛,用户量“噌”“噌”“噌”的涨 为了不掉队不落伍.在后台大哥的胁迫下,不得不选择用了它 刚开始很难接受vue的写法,在编辑器里很容易报错,基本上每行都会出现红色的波浪线 这 ...
- 使用js json/xml互相转换
<html> <head> <title>json与xml互转</title> <script type="text/javascrip ...
- JAVA实现扫描线算法
首先说一下,教科书上的扫描线算法确实是用c++很好实现,而且网上有很多源码,而java实现的基本没有(可能是我没看到),所以肖先生还是打算自己码(实验作业写这个而自己又个是写java的猿0.0). 对 ...
- 通过FeignClient接收shaded的javabean的JSON序列化
问题说明 最近做了关于flink的需求. 现在需要通过HTTP访问FLINK的 RESTAPI, rest 接口的JSON 非常庞大而复杂. 那么怎么去完整的接收数据呢? 方法一就是手写部分需要的Ja ...
- C语言 二叉树的遍历(递归和非递归)
#include <iostream> #include <cstdio> #include "biTree.h" #include "cstdl ...
- 【网络安全】HTTPS为什么比较安全
目录 HTTP和HTTPS简介 SSL协议 SSL协议的主要功能 SSL协议加密数据的原理 用户和服务器的认证流程 TLS 参考 HTTP和HTTPS简介 1. HTTP协议为什么是不安全的 http ...
- Ios 开发 mac cocoaPods的环境搭建
CocoaPods不多介绍,一个大家几乎都会使用的第三方库的管理框架! 本文主要介绍如何安装和使用CocoaPods,本人亲测可行. 1.Ruby环境搭建 查看下当前ruby版本: ruby -v 更 ...