java单链表实现书籍管理系统

本文实例为大家分享了java单链表实现书籍管理系统的具体代码,供大家参考,具体内容如下

书籍管理系统功能:

1).添加图书
2).删除图书
3).查看图书
4).修改书籍
5).修改排序方式
6).模糊查询
7).退出程序

代码实现:

Book类

package com.bookmanagement.book;

public class Book {//书类
 public String no;
 public String name;
 public int price;
 public String type;
 public Book next;

 public Book(String Bno,String Bname,int Bprive,String Btype) {
  this.no=Bno;
  this.name=Bname;
  this.price=Bprive;
  this.type=Btype;
 }
 public Book() {

 }

 //toString方法
 @Override
 public String toString() {
  return "  Bookno=" + no + ",  Bookname=" + name + ",  Bookprice=" + price + ", Booktype=" + type;
 }

}

1).添加图书

package com.bookmanagement.function;
import java.util.Scanner;
import com.bookmanagement.book.*;
public class AddBook {
 static Scanner input = new Scanner(System.in);
 public static void addbook() {

  System.out.println("请输入书编号:");
  String no = input.next();
  System.out.println("请输入书名字:");
  String name = input.next();
  System.out.println("请输入书价格:");
  int price = input.nextInt();
  System.out.println("请输入书类型:");
  String type = input.next();
  Book bo = new Book(no,name,price,type);
  add(bo);
 }
 public static void add(Book bo) {
  Book temp = Test.head;//把头节点赋值给一个辅助类
  boolean falg = false;
  while(true) {
   if(temp.next == null) {//判断链表是否到最后
    break;
   }
   if(Test.stroing %2 == 1) {//判断是否修改了显示顺序
    if(temp.next.no.compareToIgnoreCase(bo.no)<0) {//寻找适合的位置插入节点//跳过头节点
     break;
    }else if(temp.next.no.compareToIgnoreCase(bo.no)==0){
     falg = true;
     break;
    }
   }else {
    if(temp.next.no.compareToIgnoreCase(bo.no)>0) {//寻找适合的位置插入节点//跳过头节点
     break;
    }else if(temp.next.no.compareToIgnoreCase(bo.no)==0){
     falg = true;
     break;
    }

   }
   //节点后移
   temp = temp.next;
  }
  if(falg) {//判断是否输入相同的编号
   System.out.println("插入"+bo.no+"的数据编号已存在");
  }else {
   bo.next = temp.next;
   temp.next = bo;
  }

 }

}

2).删除图书

package com.bookmanagement.function;
import java.util.Scanner;
import com.bookmanagement.book.*;
public class DropBook {
 static Scanner input = new Scanner(System.in);
 public static void dropbook() {
  System.out.println("请输入需要删除图书的编号:");
  String no = input.next();
  Book temp = Test.head;
  boolean falg = false;
  while(true) {
   if(temp.next == null) {//判断链表是否到最后
    break;
   }
   if(temp.next.no.compareToIgnoreCase(no)==0) {
    falg = true;
    break;
   }
   temp = temp.next;//temp位移
  }
  if(falg) {
    temp.next=temp.next.next;//找到temp.next域指向删除的编号让下一个next覆盖
    //如果需要删除的编号下一个next域指向的是null则temp.next域则下一个指向为空
    System.out.println("删除成功");
  }else {
   System.out.println("没有找到该书籍");
  }

 }
}

3).查看图书

package com.bookmanagement.function;
import com.bookmanagement.book.*;
public class ShowBook {
 public static void showbook() {
  if(Test.head.next == null) {
   System.out.println("没有书籍数据");
   return;
  }
  Book temp = Test.head.next;//输出头节点下一个节点
  int sum=0;
  while(true) {
   if(temp == null) {
    break;
   }
   System.out.println(temp);
   sum++;
   temp = temp.next;//temp位移
  }
  System.out.println("书籍总数为:"+sum);

 }
}

4).修改书籍

package com.bookmanagement.function;
import java.util.Scanner;
import com.bookmanagement.book.*;
public class Modify {
 static Scanner input = new Scanner(System.in);
 public static void modidy() {
  System.out.println("请输入需要修改的图书的编号:");
  String no = input.next();
  Book temp = Test.head;
  boolean ts = false;
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.no.compareToIgnoreCase(no)==0) {
    ts = true;
    break;
   }
   temp = temp.next;
  }
  if(ts) {
   System.out.println("修改:1.名字 2.编号 3.价格 4.类型");
   int falg = input.nextInt();
   switch (falg) {
   case 1:
    System.out.println("请输入需要修改的名字:");
    String name = input.next();
    temp.next.name = name;
    break;
   case 2:
    System.out.println("请输入需要修改的编号:");
    String Mno = input.next();
    temp.next.no = Mno;
    Book change = temp.next;
    temp.next=temp.next.next;
    AddBook.add(change);
    //重新调用add方法
    break;
   case 3:
    System.out.println("请输入需要修改的价格:");
    int prive = input.nextInt();
    temp.next.price = prive;
    break;
   case 4:
    System.out.println("请输入需要修改的类型:");
    String type= input.next();
    temp.next.type = type;
    break;
   default:System.out.println("输入有误");
    break;
   }
  }else{
   System.out.println("没有找到该书籍");
  }
 }
}

5).修改排序方式

package com.bookmanagement.function;
import java.util.Scanner;
import com.bookmanagement.book.*;
public class Flash {
 static Scanner input = new Scanner(System.in);
 public static void flashbook() {
  Book everList = new Book("","",0,"");
  Book temp = Test.head.next;//把有数据的赋值给辅助类
  Book next = null;
  if(temp.next == null) {//链表只有一个数据不需要排序
   System.out.println("链表只有一个数据不需要逆序");
   return;
  }
  while(temp != null) {
   next = temp.next;
   temp.next = everList.next;
   everList.next = temp;
   temp = next;
  }
  Test.head.next = everList.next;
  if(Test.stroing%2==1) {
   System.out.println("修改为降序");
  }else {
   System.out.println("修改为升序");
  }
 }
}

6).模糊查询

package com.bookmanagement.function;
import com.bookmanagement.book.*;
import java.util.Scanner;
public class Detailed {
 static Scanner input = new Scanner(System.in);
 public static void detailed() {
  System.out.println("功能:模糊查询");
   detalied1();
 }
 public static void detalied1() {
  System.out.println("输入需要查找的数据:1.书名2.编号3.价格4.类型");
  int falg = input.nextInt();
  switch (falg) {
  case 1:
   DetaBookName();
   break;
  case 2:
   DetaBookNo();
   break;
  case 3:
   DetaBookPrice();
   break;
  case 4:
   DetaBookType();
   break;
  default:
   break;
  }
 }
 public static void DetaBookName() {
  System.out.println("请输入模糊书名:");
  String name = input.next();
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
   return;
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.name.indexOf(name)==0) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有找到该书籍信息");
  }
 }
 public static void DetaBookNo() {
  System.out.println("请输入模糊编号:");
  String no = input.next();
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
   return;
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.no.indexOf(no)==0) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有找到该书籍信息");
  }
 }
 static int price;
 public static void DetaBookPrice() {
  System.out.print("输入符号:(>,<,=,>=,<=,!=):");
  String symbol = input.next();
  System.out.print("输入价格:");
  price = input.nextInt();
  System.out.println();
  switch (symbol) {
  case ">":
   GreaterPrice();
   break;
  case "<":
   LessPrice();
   break;
  case "=":
   EqualPrice();
   break;
  case ">=":
   GreaterEqualePrice();
   break;
  case "<=":
   LessEqualePrice();
   break;
  case "!=":
   NotEquale();
   break;
  default:System.out.println("输入错误");
   break;
  }
 }
 public static void GreaterPrice() {
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.price>price) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有书籍符合信息");
  }
 }
 public static void LessPrice() {
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.price<price) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有书籍符合信息");
  }
 }
 public static void EqualPrice() {
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.price==price) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有书籍符合信息");
  }
 }
 public static void GreaterEqualePrice() {
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.price>=price) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有书籍符合信息");
  }
 }
 public static void LessEqualePrice() {
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.price<=price) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有书籍符合信息");
  }
 }
 public static void NotEquale() {
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.price!=price) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有书籍符合信息");
  }
 }
 public static void DetaBookType() {
  System.out.println("请输入模糊类型:");
  String type = input.next();
  Book temp = Test.head;
  boolean falg = false;
  if(Test.head.next == null) {
   System.out.println("没有书籍信息");
   return;
  }
  while(true) {
   if(temp.next == null) {
    break;
   }
   if(temp.next.type.indexOf(type)==0) {
    System.out.println(temp.next);
    falg = true;
   }
   temp = temp.next;
  }
  if(!falg) {
   System.out.println("没有找到该书籍信息");
  }
 }

}

7).测试类

package com.bookmanagement.function;

import java.util.Scanner;
import com.bookmanagement.book.*;
public class Test {
 static int stroing=0;
 public static Book head = new Book("","",0,"");//建立链表头
 public static void main(String[] args) {
  Scanner input = new Scanner(System.in);
  System.out.println("-----欢迎进入图书管理系统-----");
  boolean temp = true;
  while(temp) {
   System.out.println("1).添加图书");
   System.out.println("2).删除图书");
   System.out.println("3).查看图书");
   System.out.println("4).修改书籍");
   System.out.println("5).修改排序方式");
   System.out.println("6).模糊查询");
   System.out.println("7).退出程序");
   int choose = input.nextInt();
   switch (choose) {
   case 1:
    AddBook.addbook();//添加书籍
    break;
   case 2:
    DropBook.dropbook();//删除书籍
    break;
   case 3:
    ShowBook.showbook();//查看书籍
    break;
   case 4:
    Modify.modidy();//修改书籍
    break;
   case 5:
    stroing++;
    Flash.flashbook();//修改排序方式
    break;
   case 6:
    Detailed.detailed();//模糊查询
    break;
   case 7:
    temp = false;//退出程序
    break;
   default:System.out.println("输入错误");
    break;
   }
  }
  System.out.println("程序退出,欢迎下次使用");
  input.close();
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java控制台输出图书馆管理系统

    java控制台输出图书馆管理系统(只用java代码不用数据库和GUI,java入门的新手秒懂) 在个项目中,我只用数组保存数据,和只用for循环和if条件语句来完成,连数组工具类都没用,所以导致要用到很多的条件语句,虽然比较局限,但可以让新手快速体验一下做小项目的乐趣,也可以练练for和if这些语句,练练一下它们之间嵌套的逻辑关系等,因为时间有限所以没有去优化了,主要还是让新手们体验下做java项目的面向对象编程思想(OOP),给新手们体验一下做项目的乐趣,嘿嘿! 话不多说了,直接切入正题. 设

  • 图书管理系统java版

    本文的目的就是通过图书管理系统掌握数据库编程技术,能正确连接数据库,能对数据库中信息进行查询.插入.删除.修改. 内容:在数据库中创建一张书目信息表,包括书名.作者.出版社.出版日期.书号.价格字段.设计一个GUI界面进行书目管理.在该界面上有四个选项卡,分别是查询.插入.删除.修改.点击查询选项卡,出现的界面上有书名.作者.出版社.书号四个文本框,一个按钮和一个只读文本区.文本框内容可以为空,输入相应的查询信息后(例如根据书名查询可以仅输入书名),点击界面上的"查询"按钮,可以在界面

  • java+mysql实现图书馆管理系统实战

    本文实例为大家分享了java+mysql实现图书馆管理系统的具体代码,供大家参考,具体内容如下 概述 基于Spring + Spring MVC + MyBatis的图书馆管理系统,使用Maven进行包管理.主要功能包括:图书查询.图书管理.图书编辑.读者管理.图书的借阅与归还以及借还日志记录等. 代码 @Controller public class LendController { @Autowired private LendService lendService; @Autowired

  • java实现图书馆管理系统

    本文实例为大家分享了java实现图书馆管理系统的具体代码,供大家参考,具体内容如下 思路:所有包都在book_manage包里 利用面向对象的多态特性去除了很多if-else的判断,不同的子类在父类所对应的方法不同. 1.首先建立一个book包 包里面有2个类,一个是Book,这个类里面包含一本书的全部信息 另外一个类是BookList,这个类是用来管理每一个书,通过这个类来寻找每一本书. private Book[] books = new Book[100]; Book数组里面存放所有的书.

  • 图书管理系统java代码实现

    本文实例为大家分享了java实现图书管理系统的具体代码,供大家参考,具体内容如下 /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:    <图书管理系统--java>                          * 作    者:       刘江波                       * 完成日期:    2012     年  3    

  • 一个简陋的java图书管理系统

    本文代码为原创一个简陋的管理系统,只做功能的测试.并没有去完善所有应有的功能,只做了输入输出查找,仅供参考! 菜单部分: import java.util.Scanner; public class Menu { int Min = 1; int Max = 3; public void getMenu(){ System.out.println("1.显示/2.输入/3.查找"); } public void getFindMenu(){ System.out.println(&qu

  • JAVA初级项目——实现图书管理系统

    今天博主再给大家分享一个小项目:MiNi图书管理系统.用的是Java语言开发的,代码不多,大概260行左右吧,系统是实现图书的新增图书.删除图书.借阅图书.归还图书.查看图书等简单的功能(后附源代码)! 首先展示一下运行界面效果图:运行代码后,会在控制台显示如下界面: 然后让用户选择,如果用户不小心或者误输入了错误的数,会再次让用户进行输入. 当用户输入2后,可以查看图书,会显示已有的图书:包括图书书名.借阅状态.借阅次数.借阅日期等信息. 当用户输入1后,可以新增图书,再次让用户输入新增的图书

  • Java设计模块系列之书店管理系统单机版(一)

    书店管理系统: 项目练习目标 : 1.Java应用程序基本分析 2.培养面向对象编程的基本思想 3.Java基本设计模式综合应用 4.掌握分层和接口的基本设计 5.构建合理的Java应用程序包结构 6.综合应用JSE所学习的知识 7.在应用中合理使用集合框架 8.在应用中综合使用swing的常用组件 9.基本的表现层的实现机制 10.IO流和文件的基本操作 11.培养良好的Java编程习惯 12.培养调试Java程序的能力,培养改错的能力 项目功能需求 : 1.能进行操作用户的注册,修改基本信息

  • Java设计模块系列之书店管理系统单机版(二)

    Java-单机版的书店管理系统(练习设计模块和思想_系列 一 ): http://www.jb51.net/article/91004.htm 介绍 小提示:上面一点有一个目录,可以快速定位到自己需要看的类. 今天对前面的代码有了小小的修改,让代码更加完善了一点. 至于用户唯一标识码uuid,会在以后修改成程序内部生成的, 现在的uuid还是由用户自己设置. 今天对这个程序,添加了用户界面的表现层的一部分,增加了公共类 枚举, 下面贴出目前我写的这个程序的全部代码:我会逐渐的写完这个程序的,请大

  • Java+MySQL实现图书管理系统(完整代码)

    (完整代码+实训报告): 链接: https://pan.baidu.com/s/1E6BhEaHMa6Wch5yf6YAjOA 提取码: vnrx 觉着有用就点个赞哦~ 一,功能 管理员登录 图书借阅信息管理 图书信息管理 管理员更改密码 退出系统 二,工具 Eclipse Version: 2018-09 (4.9.0) MySQL Workbench 8.0 CE mysql-connector-java-8.0.13.jar 三.效果图: 登录界面: 主界面: 借阅书籍管理: 个人书库管

随机推荐