1234567

import java.util.Scanner;

public class VocabularyManager {

// 词汇数组(最大100个)、计数变量、扫描器

private static Word[] vocabulary = new Word[100];

private static int wordCount = 0;

private static Scanner scanner = new Scanner(System.in);

public static void main(String[] args) {

// 初始化5个测试词汇

initializeVocabulary();

// 登录流程

login();

}

// 初始化测试词汇

private static void initializeVocabulary() {

addNewWord(vocabulary, wordCount, "apple", "苹果");

addNewWord(vocabulary, wordCount, "banana", "香蕉");

addNewWord(vocabulary, wordCount, "cat", "猫");

addNewWord(vocabulary, wordCount, "dog", "狗");

addNewWord(vocabulary, wordCount, "egg", "鸡蛋");

}

// 登录逻辑:区分教师/学生

private static void login() {

System.out.println("=== 词汇管理系统登录 ===");

System.out.print("请选择角色(1-教师/2-学生):");

int role = scanner.nextInt();

scanner.nextLine(); // 吸收换行符

System.out.print("用户名:");

String username = scanner.nextLine();

System.out.print("密码:");

String password = scanner.nextLine();

// 验证登录(硬编码账号)

if (role == 1 && username.equals("teacher") && password.equals("teach123")) {

System.out.println("教师登录成功!");

teacherMenu();

} else if (role == 2 && username.equals("student") && password.equals("stud123")) {

System.out.println("学生登录成功!");

studentMenu();

} else {

System.out.println("账号或密码错误,退出系统!");

}

}

// 教师菜单(全功能)

private static void teacherMenu() {

while (true) {

System.out.println("\n=== 教师菜单 ===");

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.print("请选择操作:");

int choice = scanner.nextInt();

scanner.nextLine();

switch (choice) {

case 1:

displayAllWords(vocabulary, wordCount);

break;

case 2:

System.out.print("请输入要搜索的单词:");

String searchKey = scanner.nextLine();

int index = searchWord(vocabulary, wordCount, searchKey);

if (index != -1) {

System.out.println("找到词汇:" + vocabulary[index]);

} else {

System.out.println("未找到该词汇!");

}

break;

case 3:

System.out.print("请输入新单词:");

String newWord = scanner.nextLine();

System.out.print("请输入释义:");

String newMeaning = scanner.nextLine();

addNewWord(vocabulary, wordCount, newWord, newMeaning);

System.out.println("词汇添加成功!");

break;

case 4:

System.out.print("请输入要删除的单词:");

String delWord = scanner.nextLine();

deleteWord(vocabulary, wordCount, delWord);

break;

case 5:

System.out.print("请输入要修改的单词:");

String updateWord = scanner.nextLine();

System.out.print("请输入新释义:");

String updateMeaning = scanner.nextLine();

updateWordMeaning(vocabulary, wordCount, updateWord, updateMeaning);

break;

case 6:

System.out.println("退出系统,再见!");

System.exit(0);

default:

System.out.println("无效选择,请重新输入!");

}

}

}

// 学生菜单(仅查看、搜索)

private static void studentMenu() {

while (true) {

System.out.println("\n=== 学生菜单 ===");

System.out.println("1. 查看所有词汇");

System.out.println("2. 搜索词汇");

System.out.println("3. 退出");

System.out.print("请选择操作:");

int choice = scanner.nextInt();

scanner.nextLine();

switch (choice) {

case 1:

displayAllWords(vocabulary, wordCount);

break;

case 2:

System.out.print("请输入要搜索的单词:");

String searchKey = scanner.nextLine();

int index = searchWord(vocabulary, wordCount, searchKey);

if (index != -1) {

System.out.println("找到词汇:" + vocabulary[index]);

} else {

System.out.println("未找到该词汇!");

}

break;

case 3:

System.out.println("退出系统,再见!");

System.exit(0);

default:

System.out.println("无效选择,请重新输入!");

}

}

}

// 显示所有词汇

public static void displayAllWords(Word[] vocab, int count) {

if (count == 0) {

System.out.println("词汇列表为空!");

return;

}

System.out.println("\n=== 词汇列表 ===");

for (int i = 0; i < count; i++) {

System.out.println((i + 1) + ". " + vocab[i]);

}

}

// 搜索词汇(返回索引,-1表示未找到)

public static int searchWord(Word[] vocab, int count, String keyWord) {

for (int i = 0; i < count; i++) {

if (vocab[i].getWord().equalsIgnoreCase(keyWord)) {

return i;

}

}

return -1;

}

// 添加新词汇

public static void addNewWord(Word[] vocab, int count, String word, String meaning) {

if (count < vocab.length) {

vocab[count] = new Word(word, meaning);

wordCount++;

} else {

System.out.println("词汇列表已满,无法添加!");

}

}

// 删除词汇

public static void deleteWord(Word[] vocab, int count, String word) {

int index = searchWord(vocab, count, word);

if (index == -1) {

System.out.println("未找到该词汇,删除失败!");

return;

}

// 数组元素前移

for (int i = index; i < count - 1; i++) {

vocab[i] = vocab[i + 1];

}

vocab[count - 1] = null; // 清空最后一个元素

wordCount--;

System.out.println("词汇删除成功!");

}

// 修改词汇释义

public static void updateWordMeaning(Word[] vocab, int count, String word, String newMeaning) {

int index = searchWord(vocab, count, word);

if (index == -1) {

System.out.println("未找到该词汇,修改失败!");

return;

}

vocab[index].setMeaning(newMeaning);

System.out.println("词汇释义修改成功!");

}

}

相关推荐
Q741_14711 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
The_Ticker12 分钟前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
夏乌_Wx16 分钟前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
AI成长日志1 小时前
【笔面试算法学习专栏】哈希表基础:两数之和与字母异位词分组
学习·算法·面试
abant21 小时前
leetcode 239 单调队列 需要一些记忆
算法·leetcode·职场和发展
漫霂1 小时前
二叉树的统一迭代遍历
java·算法
炽烈小老头1 小时前
【每天学习一点算法 2026/04/08】阶乘后的零
学习·算法
Mr_Xuhhh1 小时前
算法刷题笔记:从滑动窗口到哈夫曼编码,我的算法进阶之路
开发语言·算法
MicroTech20252 小时前
突破虚时演化非酉限制:MLGO微算法科技发布可在现有量子计算机运行的变分量子模拟技术
科技·算法·量子计算
hssfscv2 小时前
软件设计师下午题六——Java的各种设计模式
java·算法·设计模式