Java - 通过数据结构实现简易通讯录

Java - 通过数据结构实现简易通讯录

仅供学习参考
编程软件:eclipse2017版

AddressBookTest是测试类

package MyADB;

import java.util.InputMismatchException;
import java.util.Scanner;

class InstructionsMistake extends Exception {
	public InstructionsMistake(String mo) {
		super(mo);
	}
}

public class AddressBookTest {

	public static void main(String[] args) throws InstructionsMistake{
		MyAddressBook AdB = new MyAddressBook();
		Scanner rb = new Scanner(System.in);
		String name = new String();
		String cell = new String();
		boolean isNum = false;
		int co = 0;

		System.out.println("********简易通讯录管理程序********");
		System.out.println("	1.插入新的联系人		 ");
		System.out.println("	2.查询已有联系人		 ");
		System.out.println("	3.更改已有联系人		 ");
		System.out.println("	4.删除已有联系人		 ");
		System.out.println("	5.显示已有联系人 		 ");
		System.out.println("	6.退出通讯录程序		 ");

		do {
			System.out.print("\n********请输入你所要操作的代码:");
			try {
				co = rb.nextInt();
			} catch (InputMismatchException e) {
				throw new InstructionsMistake("输入的操作代码有误");
			}		
			if (co == 1) {
				System.out.print("请输入新的联系人姓名:");
				name = rb.next();
				System.out.print("请输入新的联系人手机号码:");
				cell = rb.next();
				//运用正则表达式对手机号码的输入进行规范
				isNum = cell.matches("^1[3|5|7|8]\\d{9}$");
				while (!isNum) {
					System.out.print("输入的手机号码有误,请重新输入:");
					cell = rb.next();
					isNum = cell.matches("^1[3|5|7|8]\\d{9}$");
				}
				AdB.addAdB(name, cell);
				System.out.println("联系人 " + name + " 成功录入");
			} else if (co == 2) {
				System.out.print("请输入所查询的联系人姓名:");
				name = rb.next();
				String str = AdB.searchAdB(name);
				if (str == null) {
					System.out.println("找不到" + name + "联系人");
				} else {
					System.out.println("查找成功");
					System.out.println("该联系人的手机号码为:" + str);
				}
			} else if (co == 3) {
				System.out.print("请输入要更改的联系人姓名:");
				name = rb.next();
				String str = AdB.searchAdB(name);
				if (str == null) {
					System.out.println("找不到" + name + "联系人");
				} else {
					System.out.println("1/更改联系人的姓名");
					System.out.println("2/更改联系人的手机号码");
					System.out.print("请输入操作代码:");
					int cot = rb.nextInt();
					if (cot == 1) {
						System.out.print("请输入该联系人的新姓名:");
						String toName = rb.next();
						toName = AdB.ChangeAdBName(name,toName);
						System.out.println("该联系人姓名成功更改为:" + toName);
					} else if (cot == 2) {
						System.out.print("请输入该联系人的新手机号码:");
						String toCell = rb.next();
						isNum = toCell.matches("^1[3|5|7|8]\\d{9}$");
						while (!isNum) {
							System.out.print("输入的手机号码有误,请重新输入:");
							toCell = rb.next();
							isNum = toCell.matches("^1[3|5|7|8]\\d{9}$");
						}
						toCell = AdB.ChangeAdBCell(name,toCell);
						System.out.println("该联系人手机号码成功更改为:" + toCell);
					} 
				}
			} else if (co == 4) {
				System.out.print("输入要删除的联系人姓名:");
				name = rb.next();
				AdB.deleteAdB(name);
			} else if (co == 5) {
				System.out.println(AdB);
			} else if (co == 6){
				break;
			}
		} while (co != 6);
		System.out.println("********成功退出通讯录程序********");
	}

}

MyAddressBook类

package MyADB;

//双向
public class MyAddressBook {// 通讯录

	protected Node first;// 第一个联系人(通讯录的管理工具)
	protected Node last;// 最后一个联系人
	protected int size = 0;// 联系人的个数

	// 通讯录中的单个联系人
	protected class Node {// 联系人(内部类)
		Node prev;// 上一个联系人
		Node next;// 下一个联系人
		public String name;// 姓名
		public String cell;// 手机号码

		public Node(String name, String call) {
			this.name = name;
			this.cell = call;
		}
	}

	// 尾插法
	public void addAdB(String name, String call) {
		Node node = new Node(name, call);// 新建一个联系人
		if (size == 0) {
			this.first = node;
			this.last = node;
		} else {
			// 把新增联系人作为之前最后的联系人的下一个
			this.last.next = node;
			// 把最后一个联系人作为新增联系人的上一个联系人
			node.prev = this.last;
			// 把新增联系人作为通讯录的最后一个
			this.last = node;
		}
		size++;
	}

	// 查找联系人
	public String searchAdB(String name) {
		if (size == 0) {
			System.out.println("通讯录为空");
			return null;
		}
		Node current = this.first;
		for (int i = 0; i < size; i++) {
			if (!current.name.equals(name)) {
				if (current.next == null) {
					// 找不到返回空
					return null;
				}
				current = current.next;
			}
		}
		// 找到后返回该联系人的手机号码
		return current.cell;
	}

	// 返回联系人自身
	public Node retuName(String name) {
		if (size == 0) {
			System.out.println("通讯录为空");
			return null;
		}
		Node current = this.first;
		for (int i = 0; i < size; i++) {
			if (!current.name.equals(name)) {
				current = current.next;
			}
		}
		return current;
	}

	// 更改联系人姓名
	public String ChangeAdBName(String name, String toName) {
		Node current = retuName(name);
		current.name = toName;
		return current.name;
	}

	// 更改联系人手机号码
	public String ChangeAdBCell(String name, String toCell) {
		Node current = retuName(name);
		current.cell = toCell;
		return current.cell;
	}

	// 删除指定联系人
	public void deleteAdB(String name) {
		if (size == 0) {
			System.out.println("通讯录为空");
			return;
		}
		// 找到被删除的联系人
		Node current = this.first;
		for (int i = 0; i < size; i++) {
			if (!current.name.equals(name)) {
				if (current.next == null) {
					System.out.println("找不到" + name + "联系人");
					return;
				}
				current = current.next;
			}
		}
		// 进行删除操作
		if (current == first) {//删除通讯录中顶部的一个联系人
			this.first = current.next;
			if(size != 1) this.first.prev = null;	
		} else if (current == last) {//删除通讯录中最底部的一个联系人
			this.last = current.prev;// 将该联系人的上一个联系人作为通讯录的最后一个联系人
			this.last.next = null;// 最后一个联系人对下一个联系人引用为空
		} else {
			// 将该联系人的下一个联系人作为该联系人的上一个联系人的next
			current.prev.next = current.next;
			// 将该联系人的上一个联系人作为该联系人的下一个联系人的prev
			current.next.prev = current.prev;
		}
		size--;
		System.out.println("已将 " + name + "移除通讯录");
	}

	public String toString() {
		if (size == 0) {
			return "通讯录为空";
		}
		// 拼接字符串
		StringBuilder sbBuilder = new StringBuilder(size * 2 + 1);
		Node current = this.first;
		int counet = 0;
		while (current != null) {
			sbBuilder.append("联系人姓名为:" + current.name + "\n");
			sbBuilder.append("该联系人手机号码为:" + current.cell + "\n");
			if (counet != size - 1) {
				sbBuilder.append("\n");
				counet++;
			}
			current = current.next;
		}
		return sbBuilder.toString();
	}

}

  • 5
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
*:手机通讯录联系人分类: 亲人 同事 朋友 其他 *:手机通讯录里面所有的联系人底层都装进一个集合对象里面 -》 ArrayList *:亲人 同事 朋友 其他类型里面所有的属性: char szm;->首字母 String name->联系人名字 int age->联系人年龄 char gender->联系人性别 long phone->手机号码 String zuoJi->座机号码 -》类似: 0531-6661760 *:创建联系人对象的时候: szm name age gender phone是必填内容 zuoJi可填可不填 *:如果创建联系人对象的时候 用户如果没有提供zuoJi属性值 那么将zuoJi变量赋值为"无座机号码" *:如果创建联系人对象的时候 用户如果提供zuoJi属性值了 那么直接将zuoJi变量赋值为用户输入的值 *:所有类里面的属性要求封装 //一个模块一个模块写 写完测试 测试通过写下一个模块 刚进入cmd里面的主界面 -》 6个小模块 A:显示所有联系人 B:查找某一位联系人 C:添加联系人 D:删除联系人 E:修改联系人 F:结束当前所有操作 显示所有联系人 如果用户选择是A 那么有两种选择: 输入校验: 用户可能输进去的不是a/b 要求重新输入 所有的输入都需要进行校验 a:按照首字母进行显示分类: [效果如下:] A 阿磊 1555950427 W 王刚美 18322009876 X 小明 18756789000 Z 张三 15555555555 周凯 18765432189 .... b:按照类别进行分类显示: [效果如下:] 朋友 张三 15555555555 小明 18756789000 周树人 17499990427 张三 15555445555 亲人 王刚美 18322009876 周凯 18765432189 同事 阿磊 1555950427 ... 查找某一位联系人 如果用户选择的是B: cmd面板显示下面这句话: 请问你是通过联系人名字进行精确查找/手机号码模糊查询 这里用户有两种选择: 用户可以直接的输入要查找联系人的名字 如果集合里面没有该用户 直接显示: 不好意思 当前用户不存在 如果集合里面有该用户 需要将用户的基本信息进行展示: [效果如下:] [输入]张三 [显示] 用户的基本信息: 联系人姓名:张三 联系人电话:15555555555 联系人座机号码:0531-6661760 用户的基本信息: 联系人姓名:张三 联系人电话:15555445555 联系人座机号码:无座机号码 用户还可以直接输入一段电话号码-》出现几个数字就可以 如果集合里面没有用户的号码出现这几个数字的 直接显示: 不好意思 当前用户不存在 如果查找到有这个用户存在 显示下面: [效果如下:] [输入]555555 [显示] 用户的基本信息: 联系人姓名:张三 联系人电话:15555555555 联系人座机号码:0531-6661760 添加联系人 如果用户选择的是C: 需要进行输入校验: 1:输入的大写首字母可能不是大写首字母 是数字 是其他的汉字 2:性别选择的不是A/B 3:注册用户名字的时候 应国家要求 关键字需要屏蔽(...) 4: 输入电话号码的时候 非11为数字 不是数字 不是以138 130 137 158 155 188. .开头 5:输入的年龄非数字 6:选择的分类可能不是亲人 朋友 同事 其他 7:座机可能不是按照 区号-号码的形式传进去的 座机号码的区号只能出现0564 0531 0532 cmd里面直接出现下面的内容: 请选择联系人的分类A:亲人 B:同事 C:朋友 D:其他 请输入联系人名字大写首字母: 请输入联系人的姓名: 请输入联系人的年龄: 请选择联系人性别:A:男 B:女 请输入联系人的电话: 请输入联系人座机号码(没有请回复N):N/区号-座机号 当用户依次输入所有的信息之后 产生一个联系人 但是需要判断集合里面是否已经存在该用户 如果存在(只要手机号码相同就认为是同一个联系人) 这个联系人存在不能继续添加进通讯录里面 cmd里面显示:对不起 当前用户已经存在 同一个用户不能添加多次 如果不存在 将当前联系人添加进集合里面 cmd里面显示:添加成功 删除联系人 如果用户选择的是D: 直接在cmd里面先以表的形式将所有联系人的信息显示出来: [效果如下:] 编号 姓名 年龄 电话 0 张三 22 155****5555 1 小明 18 187****9000 2 王刚美 28 183****9876 3 阿磊 24 155****4278 4 周凯 38 187****2189 5 周树人 99 174****0427 6 张三 22 155****5555 cmd里面显示:请问你要删除联系人的编号: 输入校验: 需要对当前输入的编码进行判断 是不是数字 如果不是 需要重新输入(从新输进去的内容还是需要进行输入校验) 如果集合里面有该编码对象的元素 从集合里面将当前编号的联系人删除 并在cmd里面显示删除成功 如果集合里面没有该编号对应的联系人 cmd里面显示:对不起 没有该编码对应的联系人 修改联系人 如果用户选择的是E: 输入校验: 修改之后的姓名还是不能出现关键字 修改之后的电话号码还是只能以155 159...开头 修改后的大写首字母还是要判断是否合法 可能用户不是按照格式正确输入 XXX-XXX-XXX(无论是修改前的输入还是修改后的输入格式需要正确) [效果如下] 请输入你要修改联系人的姓名大写首字母 姓名 联系电话(中间-隔开):Z-张三-15555555555 请输入修改后的联系人的姓名大写首字母 姓名 联系电话(中间-隔开):L-李四-18900000000 找到集合里面对应的联系人将信息修改掉 修改完毕 显示修改成功 如果集合里面没有找到叫张三的联系人 显示修改失败 没有查找到该联系人 结束当前所有操作 如果用户选择的是F: 直接结束当前所有的操作 -》 break
第一个模块——主函数main()的功能是:根据选单的选项调用各函数,并完成相应的功能。 
   第二个模块——Menu()的功能是:显示提示选单。 
   第三个模块——Quit()的功能是:退出选单。 
   第四个模块——Create()的功能是:创建新的数据记录。 
   第五个模块——Add()的功能是:增加新的数据记录,并返回选单。 
   第六个模块——Find()的功能是:按要求查询相关的信息,如果找到了,则显示该信息,如果未找到,则提示文件中没有该信息,并返回选单。 
   第七个模块——Alter()[的功能是:修改某条记录的信息,如果未找到要修改的记录,则提示系统中无此记录,并返回选单。 
   第八个模块——Delete()的功能是:删除某条记录,如果未找到要删除的记录,则提示通讯录中没有,并返回选单。 
   第九个模块——List()的功能是:显示所有记录。 一、用链表或者顺序表实现以下系统,完成线性表的建立(至少包括10个结点),以及线性表中信息(结点)的插入、查找、删除、修改、输出等操作,具体的模块要求见上方的“总的模块要求”。建议用“文件”存储数据。 1.通讯录管理系统的设计与实现 (1)通讯者信息包括:编号(char num[10])、姓名(char name[10])、性别(char sex[10])、电话(char phone[20]) (2)除了总的模块要求外,还需统计通讯录中男性人数及女性人数,并求出通讯录中的第一个模块——主函数main()的功能是:根据选单的选项调用各函数,并完成相应的功能。 
   第二个模块——Menu()的功能是:显示提示选单。 
   第三个模块——Quit()的功能是:退出选单。 
   第四个模块——Create()的功能是:创建新的数据记录。 
   第五个模块——Add()的功能是:增加新的数据记录,并返回选单。 
   第六个模块——Find()的功能是:按要求查询相关的信息,如果找到了,则显示该信息,如果未找到,则提示文件中没有该信息,并返回选单。 
   第七个模块——Alter()[的功能是:修改某条记录的信息,如果未找到要修改的记录,则提示系统中无此记录,并返回选单。 
   第八个模块——Delete()的功能是:删除某条记录,如果未找到要删除的记录,则提示通讯录中没有,并返回选单。 
   第九个模块——List()的功能是:显示所有记录。 一、用链表或者顺序表实现以下系统,完成线性表的建立(至少包括10个结点),以及线性表中信息(结点)的插入、查找、删除、修改、输出等操作,具体的模块要求见上方的“总的模块要求”。建议用“文件”存储数据。 1.通讯录管理系统的设计与实现 (1)通讯者信息包括:编号(char num[10])、姓名(char name[10])、性别(char sex[10])、电话(char phone[20]) (2)除了总的模块要求外,还需统计通讯录中男性人数及女性人数,并求出通讯录中的男女比例。 男女比例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我宁愿相信这是梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值