定义图书类Book,包含图书名(name)和价格(price)两个数据成员。将若干个图书 对象存放到一个链表中,然后再用Book类创建一个新的对象,并检查这本图书的定 价和链表中哪些图书的定价相同。
输出示例如下:
代码:
package book;
import java.util.*;
class Book{
private String name;
private double price;
String[] temp=new String[5];
int count=0;
public Book(String name,double price){
this.name=name;
this.price=price;
}
public void search(){
LinkedList<String> list=new LinkedList<String>();
list.add("C++ 基础教程(29.5)");
list.add("java基础教程(29.5)");
list.add("数据库原理(29.5)");
list.add("操作系统原理(28.0)");
list.add("现代操作系统(26.0)");
Iterator<String> iter=list.iterator();
while(iter.hasNext()){
String te=iter.next();
if((te.substring(te.indexOf("(")+1,te.indexOf(")"))).equals(""+price)){
temp[count]=te;
count=count+1;
}
}
System.out.printf("新书:"+name+"("+price+")"+"与下列图书价格相同:"+"\n");
for(int i=0;i<=temp.length;i++){
if(temp[i]==null){
break;
}
else{
System.out.println(temp[i]);
}
}
}
}
public class main_1 {
public static void main(String args[]){
Book b=new Book("java与模式",29.5);
b.search();
}
}
如果书本的价格不用括号括起来,又该怎么样来取出价格呢?吃饭去了,后面研究研究再补充。
如果书本和价格是name+" "+price形式,则利用substring(int startpoint)是从startpoint位置复制到字符串末尾,则只需找到对应的整形位置就好,此时可借助indexOf(String s)方法返回位置,代码和结果如下:
package book;
import java.util.*;
class Book{
private String name;
private double price;
String[] temp=new String[5];
int count=0;
public Book(String name,double price){
this.name=name;
this.price=price;
}
public void search(){
LinkedList<String> list=new LinkedList<String>();
list.add("C++ 基础教程 29.5");
list.add("java基础教程 29.5");
list.add("数据库原理 29.5");
list.add("操作系统原理 28.0");
list.add("现代操作系统 26.0");
Iterator<String> iter=list.iterator();
while(iter.hasNext()){
String te=iter.next();
if((te.substring(te.lastIndexOf(" ")+1).equals(""+price))){
temp[count]=te;
count=count+1;
}
}
System.out.printf("新书:"+name+" "+price+"与下列图书价格相同:"+"\n");
for(int i=0;i<=temp.length;i++){
if(temp[i]==null){
break;
}
else{
System.out.println(temp[i]);
}
}
}
}
public class main_1 {
public static void main(String args[]){
Book b=new Book("java与模式",29.5);
b.search();
}
}
新书:java与模式 29.5与下列图书价格相同:
java基础教程 29.5
数据库原理 29.5
可见,“C++ 基础教程”并没有出现,这是由于index从头开始检索,c++和基础教程之间有个空格,产生了干扰。为了避免这种情况,我们使用lastIndexOf方法从后往前检索空格。代码和结果如下:
package book;
import java.util.*;
class Book{
private String name;
private double price;
String[] temp=new String[5];
int count=0;
public Book(String name,double price){
this.name=name;
this.price=price;
}
public void search(){
LinkedList<String> list=new LinkedList<String>();
list.add("C++ 基础教程 29.5");
list.add("java基础教程 29.5");
list.add("数据库原理 29.5");
list.add("操作系统原理 28.0");
list.add("现代操作系统 26.0");
Iterator<String> iter=list.iterator();
while(iter.hasNext()){
String te=iter.next();
if((te.substring(te.lastIndexOf(" ")+1).equals(""+price))){
temp[count]=te;
count=count+1;
}
}
System.out.printf("新书:"+name+" "+price+"与下列图书价格相同:"+"\n");
for(int i=0;i<=temp.length;i++){
if(temp[i]==null){
break;
}
else{
System.out.println(temp[i]);
}
}
}
}
public class main_1 {
public static void main(String args[]){
Book b=new Book("java与模式",29.5);
b.search();
}
}
新书:java与模式 29.5与下列图书价格相同:
C++ 基础教程 29.5
java基础教程 29.5
数据库原理 29.5
问题解决!