java实训之利用数组与类做一个电话簿

Telphone类

package Telphone;

public class Telphone {
	private String name;//姓名
	private String sex;//性别
	private int age;//年龄
	private String tel;//电话
	private int qq;//QQ
	private String adress;//地址
	public Telphone(String name, String sex, int age, String tel, int qq, String adress) {
		super();
		this.name = name;
		this.sex = sex;
		this.age = age;
		this.tel = tel;
		this.qq = qq;
		this.adress = adress;
	}
	public Telphone() {
		super();
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getSex() {
		return sex;
	}
	public void setSex(String sex) {
		this.sex = sex;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public String getTel() {
		return tel;
	}
	public void setTel(String tel) {
		this.tel = tel;
	}
	public int getQq() {
		return qq;
	}
	public void setQq(int qq) {
		this.qq = qq;
	}
	public String getAdress() {
		return adress;
	}
	public void setAdress(String adress) {
		this.adress = adress;
	}
	
	

}

package Telphone;

import java.util.Scanner;

public class Test {
	static int N=5;
//1.添加  2.修改 3.删除  4.查询所有  5.根据姓名查询 6.退出
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Telphone[] tel=new Telphone[N];
		
		for(int x=0;x<N;x++) {//初始化电话簿,给几个人
			 tel[x]=new Telphone(""+x,"男",0,"",0,"");
		}
		Frame();
		System.out.println();
		System.out.println("请输入指令:");
		Scanner sc=new Scanner(System.in);
		int i=sc.nextInt();
		String name;
		int j=0;//接收电话簿人数
		boolean flag=false;
		while(i!=0) { 
			
			switch(i) {
				case 1:
					j=findAll(tel);
					if(j>N)
						System.out.println("电话簿已满,无法添加");
					else
						flag=addTel(tel);
					if(flag==true)
						System.out.println("添加成功!");
					break;
				case 2:
					System.out.println("输入要修改的人的姓名");
					name=sc.next();
					flag=updateTel(tel,name);
					if(flag==true)
						System.out.println("修改成功!");
					else 
						System.out.println("修改失败!");
					break;
				case 3:
					System.out.println("输入要删除人的姓名:");
					name=sc.next();
					flag=delTel(tel,name);
					if(flag==true)
						System.out.println("删除成功!");
					else 
						System.out.println("删除失败!");
					break;
				case 4:
					j=findAll(tel);
					if(j==0)
						System.out.println("当前电话簿无记录!");
					break;
				case 5:
					System.out.println("输入要查找的人的姓名");
					name=sc.next();
					findByName(tel,name);
					System.out.println();
					break;
				case 0:
					System.out.println("退出系统!");
					break;
				default:
					System.out.println("输入指令错误!");
	
			}
			name="";
			flag=false;
			System.out.println("请输入指令:");
			i=sc.nextInt();
		}
		System.out.println("退出系统!");
		
	}
	public static void Frame() {//主界面
		System.out.print("=================================================================");
		System.out.println();
		System.out.print("1.添加   2.修改   3.删除   4.查询所有   5.根据姓名查询    0.退出");
		System.out.println();
		System.out.print("=================================================================");
	}
	public static boolean addTel(Telphone[] tel1) {//添加
		Scanner sc=new Scanner(System.in);
		boolean flag=false;
		String s;
		int j=0;
		for(int i=0;i<N;i++) {//遍历数组,找到空的地方即插入
			if(tel1[i].getAge()==0) {
				System.out.println("请输入信息:");
				System.out.print("姓名:");
				s=sc.next();
				tel1[i].setName(s);
				System.out.print("性别:");
				s=sc.next();
				tel1[i].setSex(s);
				System.out.print("年龄:");
				j=sc.nextInt();
				tel1[i].setAge(j);
				System.out.print("手机:");
				s=sc.next();
				tel1[i].setTel(s);
				System.out.print("QQ:");
				j=sc.nextInt();
				tel1[i].setQq(j);
				System.out.print("地址:");
				s=sc.next();
				tel1[i].setAdress(s);
				flag=true;//添加成功后则返回true
				break;
			}
		}
		return flag;
		
	}
	public static boolean delTel(Telphone[] tel1,String name) {//删除
		boolean flag=false;
		for(int i=0;i<N;i++) {
			if(tel1[i].getName().equals(name)) {//将数组内容做成0,null形式,并非真的删除,而是设计其无法查出
				tel1[i].setName("");
				tel1[i].setSex("男");
				tel1[i].setAge(0);
				tel1[i].setTel("");
				tel1[i].setQq(0);
				tel1[i].setAdress("");
				flag=true;
				break;
			}
		}
		return flag;
		
	}
	public static boolean updateTel(Telphone[] tel1,String name) {//修改
		Scanner sc=new Scanner(System.in);
		boolean flag=false;
		String s;		
		for(int i=0;i<N;i++) {
			if(tel1[i].getName().equals(name)) {//判断姓名是否匹配
				System.out.println("请输入信息:");
				System.out.print("姓名:");
				tel1[i].setName(sc.next());
				System.out.print("性别:");
				tel1[i].setSex(sc.next());
				System.out.print("年龄:");
				tel1[i].setAge(sc.nextInt());
				System.out.print("手机:");
				tel1[i].setTel(sc.next());
				System.out.print("QQ:");
				tel1[i].setQq(sc.nextInt());
				System.out.print("地址:");
				tel1[i].setAdress(sc.next());
				flag=true;
				break;
			}
		}
		return flag;
		
	}
	public static int findAll(Telphone[] tel1) {//查所有
		int i=0;
		int j=0;
		for(i=0;i<N;i++) {//遍历数组,只要其年龄不是默认值0,则可判断其内有数据
			if(tel1[i].getAge()!=0) {
				System.out.print("姓名:"+tel1[i].getName()+" 性别:"+tel1[i].getSex()+" 年龄:"+tel1[i].getAge()+" 手机:"+tel1[i].getTel()+" QQ:"+tel1[i].getQq()+" 地址"+tel1[i].getAdress());
				System.out.println(i);
				j++;
				
			}else
				break;
		}
		return j;//返回电话簿的人数
		
		
	}
	public static void findByName(Telphone[] tel1,String name) {//查姓名
		for(int i=0;i<N;i++) {
			if(tel1[i].getName().equals(name)) {
				System.out.print("姓名:"+tel1[i].getName()+" 性别:"+tel1[i].getSex()+" 年龄:"+tel1[i].getAge()+" 手机:"+tel1[i].getTel()+" QQ:"+tel1[i].getQq()+" 地址"+tel1[i].getAdress());
				
			}
		}
		
	}
	

}

运行结果如图:由于运行环境问题,尽量输入英文,避免异常
在这里插入图片描述
在这里插入图片描述

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
*:手机通讯录联系人分: 亲人 同事 朋友 其他 *:手机通讯录里面所有的联系人底层都装进一个集合对象里面 -》 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
好的,我很乐意用中文回答你的问题。 假设你有一个电话簿,其中包含许多联系人和他们的电话号码。你想要对这个电话簿进行整理,以便可以轻松地查找联系人并按照字母顺序排序。 这就是使用Java集合中的TreeSet的好处。TreeSet是一种基于红黑树实现的有序集合,可以对元素进行自然排序(按照它们的自然顺序进行排序)或使用指定的Comparator进行排序。 在这个电话簿的例子中,你可以创建一个TreeSet,其中包含每个联系人的姓名作为元素。由于TreeSet是有序的,因此你可以轻松地按照字母顺序查找联系人。如果你想使用Comparator来排序联系人,可以创建一个Comparator并将其传递给TreeSet的构造函数。 下面是使用TreeSet来整理电话簿的一些示例代码: ```java import java.util.TreeSet; public class PhoneBook { public static void main(String[] args) { // 创建一个TreeSet用于存储联系人的姓名 TreeSet<String> contacts = new TreeSet<>(); // 添加联系人的姓名 contacts.add("Alice"); contacts.add("Bob"); contacts.add("Charlie"); contacts.add("David"); // 打印出已经排序后的联系人列表 System.out.println("Sorted phone book:"); for (String contact : contacts) { System.out.println(contact); } } } ``` 这段代码创建了一个TreeSet,并向其中添加了几个联系人的姓名。然后,它打印出已经排序后的联系人列表,这个列表按照字母顺序排列。你可以在这个基础上继续添加更多的联系人,或者实现更复杂的功能来整理电话簿
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

彭祥.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值