package com.cos.lession08.demo3;
import java.util.Arrays;
import java.util.Scanner;
public class SimpleNameSystem {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
String[] names = { "张三", "李四", "王五", "赵六", "田七"};
System.out.println("请输入要执行的操作");
System.out.println("1.修改名字\t2.添加新名字");
String chose = input.next();
switch (chose) {
case "1":
chageName(input, names);
break;
case "2":
names=addName(names);
break;
default:
break;
}
}
//添加新的名字
public static String[] addName(String[] names) {
Scanner input = new Scanner(System.in);
System.out.println("请输入您要添加的傻子");
String name = input.next();
System.out.println(names.length);
//1 判断数组中是否需要扩容
names=checkArr(names);
System.out.println(names.length);
setName(name, names);
//3 输出打印新的名字数组数据
// Arrays.toString(names); 会把数组的数据转成字符串返回出来
String result = Arrays.toString(names);
System.out.println(result);
return names;
}
public static void setName(String name,String[] names){
for (int i = 0; i < names.length; i++) {
if (names[i]==null) {
names[i]=name;
//赋值成功中断循环
return;
}
}
}
/**
* 数组扩容方法
* @param names
* @return
*/
public static String[] checkArr(String[] names) {
for (String string : names) {
//判断数组是不是有空位,只需要判断数组中是否有默认值即可,string默认值null
// ==比较内存地址 ,只要是引用类型判断是否为空(null)就要使用null
if (string==null) {
//如果有空位的时候,就返回老的内存地址
return names;
}
}
//没有空位的时候,就扩容出新的数组,返回新的内存地址出去
return Arrays.copyOf(names, names.length*2);
}
public static void chageName(Scanner input, String[] names) {
System.out.println("请输入要替换的名字");
String name = input.next();
int index = search(name, names);
if (index==-1) {
System.out.println("没有找这个名字");
}else {
System.out.println("请输入要替换的新名字");
String newName = input.next();
names[index]=newName;
}
System.out.println("==========================");
for (String string : names) {
System.out.println(string);
}
}
/**
* 在数组中查找用户输入名字是否存在
* @param name
* @param names
* @return
* 如果找到了就返回该名字在数组中所在的下标位置,如果没有找到就返回-1
*/
public static int search(String name, String[] names) {
for (int i = 0; i < names.length; i++) {
if (name.equals(names[i])) {
return i;
}
}
return -1;
}
}