IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 通讯录管理系统(链表)-C语言 -> 正文阅读

[数据结构与算法]通讯录管理系统(链表)-C语言

//通讯录管理系统
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <windows.h>
typedef struct student
{
	char name[20];         //姓名
	char num[15];          //学号
	char sex[10];          //性别
	char from[20];         //籍贯 
	char political[10];    //政治面貌
	char phone[15];        //手机号====>唯一 
	char QQ[15];           //QQ号
	char dorm[10];         //宿舍
	struct student *next;  //结构体指针
}stu;
stu *head = NULL;
int i = 1;
void menu();
void help(); 
void next(); 
void look_data(stu *head);
void input_data();
void insert_data();
void deleted_data();
void find_data(); 
void update_data();
void save_data();
int main()
{
	int label = 0;
	while(1)
	{
		menu(); 
		scanf("%d", &label);
		switch(label)
		{
			case 1:  help();           break;  //帮助 
			case 2:  input_data();     break;  //插入多条数据
			case 3:  find_data();      break;  //查询数据
			case 4:  deleted_data();   break;  //删除数据
			case 5:  save_data();      break;  //保存数据
			case 6:  look_data(head);  break;  //显示数据
			case 7:  update_data(head);break;  //修改数据
			case 8:  insert_data();    break;  //插入一条数据
			case 9:  exit(0);          break;  //退出 
			default: next();           break;  //待开发模块
		}
	}
	return 0;
}
void menu()          //显示菜单 
{
	system("cls");
	printf("\n");
	printf("********************************************************************************************\n");
	printf("*                                      通讯录管理系统                                      *\n");
	printf("********************************************************************************************\n");
	printf("****************************************系统功能菜单****************************************\n");
	printf("--------------------------------------------------------------------------------------------\n");
	printf("********************************************************************************************\n");
	printf("****           1、系统使用帮助              ****               2、插入多条数据          ****\n");
	printf("********************************************************************************************\n");
	printf("****           3、查询数据                  ****               4、删除数据              ****\n");
	printf("********************************************************************************************\n");
	printf("****           5、保存数据                  ****               6、显示数据              ****\n");
	printf("********************************************************************************************\n");
	printf("****           7、修改数据                  ****               8、插入一条数据          ****\n");
	printf("********************************************************************************************\n");
	printf("****           9、退出系统                  ****            ====》待开发模块《====      ****\n");
	printf("********************************************************************************************\n");
	printf("--------------------------------------------------------------------------------------------\n");
}

//使用帮助 
void help()
{
	system("cls");
	printf("\n          这是一个学生管理系统,为方便您更快了解它,请先阅读以下注意事项:                \n");
    printf("\n                                        注意事项:                                         \n");
    printf("\n               1、请根据提示进行操作!                                                    \n");
    printf("\n               2、初次使用请先选择输入数据!                                              \n");
    printf("\n               3、按照菜单提示键入数字代号!                                              \n");
    printf("\n               4、增加数据后,切记保存!                                                   \n");
    printf("\n               5、若您之前使用过,下次进入系统请先刷新学生信息!                          \n");
    printf("\n               6、使用遇到任何问题请与我们联系,电话:110、119、120\n");
    printf("\n               7、最后感谢您的使用!                                                      \n");
    system("pause");    //让系统暂停
}
//待开发模块 
void next()
{
	system("cls");
	printf("\n");
	printf("********************************************************************************************\n");
	printf("****                               ====》此模块待开发《====                             ****\n");
	printf("********************************************************************************************\n");
	system("pause");    //让系统暂停
}
void input_data()
{
	stu *p1 = NULL, *p2 = NULL;
	int m = 1;
	system("cls");
	printf("****                                 ====》输入数据《====                               ****\n");
	printf("****                                ====》ok代表结束《====                              ****\n");
	while(m)
	{
		printf("\n--------------------------------------------------------------------------------------------\n");
		p1 = (stu *)malloc(sizeof(stu));
		p1->next = NULL;
		if(p1 == NULL)
		{
			printf("malloc error!!\r\n");
			return ;
		}
		printf("\n手机号:");
		scanf("%s", &p1->phone);
		if(strcmp(p1->phone, "ok") == 0)
		{
			printf("\n输入完毕!!\n");
			free(p1);
			m = 0;
			break;
		}
		stu *tmp = head;
		while(tmp != NULL)
		{
			if(strcmp(tmp->phone, p1->phone) == 0)
			{
				printf("\n该学生已经存在!!\n");
				break;
			}
			p2 = tmp;   //==============>也可以将p2定义为全局尾指针 
			tmp = tmp->next;
		}
		if(tmp == NULL)
		{
			printf("\n姓名:");
			scanf("%s", &p1->name);
			printf("\n性别:");
			scanf("%s", &p1->sex);
			printf("\n籍贯:");
			scanf("%s", &p1->from);
			printf("\n政治面貌:");
			scanf("%s", &p1->political);
			printf("\n学号:");
			scanf("%s", &p1->num);
			printf("\nQQ号:");
			scanf("%s", &p1->QQ);
			printf("\n宿舍:");
			scanf("%s", &p1->dorm);
			if(i == 1)
			{
				head = p1;
				i = 2;
			}
			else
				p2->next = p1;	
			p2 = p1;
		}
		printf("\n--------------------------------------------------------------------------------------------\n");
	}
	system("pause");
}
//查看全部数据 
void look_data(stu *head)
{
	system("cls");
	printf("****                                  ====》显示数据《====                                ****\n");
	stu *tmp = head;
	printf("\n--------------------------------------------------------------------------------------------\n");
	while(tmp != NULL)
	{
		printf("姓名:%s\n", tmp->name);
		printf("学号:%s\t", tmp->num);
		printf("性别:%s\t", tmp->sex);
		printf("籍贯:%s\t", tmp->from);
		printf("政治面貌:%s\t", tmp->political);
		printf("手机号:%s\t", tmp->phone);
		printf("QQ号:%s\t", tmp->QQ);
		printf("宿舍:%s\n", tmp->dorm);
		tmp = tmp->next;
	}
	printf("\n--------------------------------------------------------------------------------------------\n");
	system("pause");
}
//插入数据 
void insert_data()
{
	stu *p1 = NULL;
	p1 = (stu *)malloc(sizeof(stu));
	p1->next = NULL;           //申请过来空间next就让其指向NULL 以免成为野指针 
	if(p1 == NULL)
	{
		printf("malloc error!!\r\n");
		return ;
	}
	printf("\n手机号:");
	scanf("%s", &p1->phone);
	stu *tmp = head;
	while(tmp != NULL)
	{
		if(strcmp(tmp->phone, p1->phone) == 0)
		{
			printf("\n该学生已经存在!!\n");
			break;
		}
		tmp = tmp->next;
	}
	if(tmp == NULL)
	{
		printf("\n姓名:");
		scanf("%s", &p1->name);
		printf("\n性别:");
		scanf("%s", &p1->sex);
		printf("\n籍贯:");
		scanf("%s", &p1->from);
		printf("\n政治面貌:");
		scanf("%s", &p1->political);
		printf("\n学号:");
		scanf("%s", &p1->num);
		printf("\nQQ号:");
		scanf("%s", &p1->QQ);
		printf("\n宿舍:");
		scanf("%s", &p1->dorm);
		if(i == 1)
		{
			head = p1;
			i = 2;
		}
		else
		{
			int label = 0;
			char phoned[20];
			stu *mmp = head, *p2;
			system("cls");
			printf("********************************************************************************************\n");
			printf("******************************************插入选项******************************************\n");
			printf("--------------------------------------------------------------------------------------------\n");
			printf("********************************************************************************************\n");
			printf("****  1、首位置插入          2、尾位置插入         3、特定位置前插       其他:取消插入 ****\n");
			printf("********************************************************************************************\n");
			printf("\n请输入你的选择:");
			scanf("%d", &label);
			switch(label)
			{
				case 1:
					p1->next = mmp;
					head = p1;
					break;
				case 2:
					while(mmp->next != NULL)
					{
						mmp = mmp->next;
					}
					mmp->next = p1;
					break;
				case 3:
					printf("\n请输入手机号(前插):");
					scanf("%s", phoned);
					while(strcmp(phoned, mmp->phone) != 0)
					{
						p2 = mmp;
						mmp = mmp->next;
					}
					p1->next = mmp;
					p2->next = p1;
					break;
				default:
					free(p1);
					break;
			}
			printf("插入成功!!!!\n");
		}	
	}
	return ;
} 
//删除数据 
void deleted_data()
{
	char phone[11];
	printf("\n请输入你要删除的手机号:");
	scanf("%s", phone);
	stu *tmp = head, *nmmp;
	int flag = 0;
	if(tmp == NULL)
	{
		printf("你的通讯录还没有添加人员!!\n");
		system("pause");
		return ; 
	}
	while(tmp)
	{
		if(0 == strcmp(phone, tmp->phone))
		{
			flag = 1;
			nmmp->next = tmp->next;
			free(tmp);
			printf("删除成功!\n");
			break; 
		}
		nmmp = tmp;
		tmp = tmp->next;
	}
	if(flag == 0)
		printf("这个学生不存在!!\n"); 
	system("pause");
}
//查找数据
void find_data()
{
	char phone[11];
	printf("\n请输入你要查找的手机号:");
	scanf("%s", phone);
	stu *tmp = head, *nmmp;
	int flag = 0;
	if(tmp == NULL)
	{
		printf("你的通讯录还没有添加人员!!\n");
		system("pause");
		return ; 
	}
	while(tmp)
	{
		if(0 == strcmp(phone, tmp->phone))
		{
			flag = 1;
			printf("你要找到的数据\n");
			printf("姓名:%s\n", tmp->name);
			printf("学号:%s\t", tmp->num);
			printf("性别:%s\t", tmp->sex);
			printf("籍贯:%s\t", tmp->from);
			printf("政治面貌:%s\t", tmp->political);
			printf("手机号:%s\t", tmp->phone);
			printf("QQ号:%s\t", tmp->QQ);
			printf("宿舍:%s\n", tmp->dorm);
			printf("查找成功!\n");
			break; 
		}
		tmp = tmp->next;
	} 
	if(flag == 0)
		printf("这个学生不存在!!\n"); 
	system("pause");
}
//修改数据 
void update_data()
{
	char phone[11];
	printf("\n请输入你要修改人的手机号:");
	scanf("%s", phone);
	stu *tmp = head;
	int flag = 0;
	if(tmp == NULL)
	{
		printf("你的通讯录还没有添加人员!!\n");
		system("pause");
		return ; 
	}
	while(tmp)
	{
		if(0 == strcmp(phone, tmp->phone))
		{
			flag = 1;
			printf("你要找到的数据\n");
			printf("姓名:%s\n", tmp->name);
			printf("学号:%s\t", tmp->num);
			printf("性别:%s\t", tmp->sex);
			printf("籍贯:%s\t", tmp->from);
			printf("政治面貌:%s\t", tmp->political);
			printf("手机号:%s\t", tmp->phone);
			printf("QQ号:%s\t", tmp->QQ);
			printf("宿舍:%s\n", tmp->dorm);
			printf("请选择要修改的信息\n");
			printf("\t1.姓名\t2.学号\t3.性别\t4.籍贯\n\t5.政治面貌\t6.手机号\t7.QQ\t8.宿舍\n");
			printf("\n您的选择是(1~8):");
			scanf("%d", &i);
			printf("请输入修改之后的内容\n");
			switch(i)
			{
				case 1:printf("姓名:");
					scanf("%s", &tmp->name);
					break;
				case 2:printf("学号:");
				    scanf("%s", &tmp->num);
				    break;
				case 3:printf("性别:");
				    scanf("%s", &tmp->sex);
				    break;
				case 4:printf("籍贯:");
				    scanf("%s", &tmp->from);
				    break;
				case 5:printf("政治面貌:");
				    scanf("%s", &tmp->political);
				    break;
				case 6:printf("手机号:");
				    scanf("%s", &tmp->phone);
				    break;
				case 7:printf("QQ:");
				    scanf("%s", &tmp->QQ);
				    break;
				case 8:printf("宿舍:");
				    scanf("%d", &tmp->dorm);
				    break;
            }
            printf("修改成功!!!"); 
		}
		tmp = tmp->next;
	} 
	if(flag == 0)
		printf("这个学生不存在!!\n"); 
	system("pause");
}
//保存数据 
void save_data()
{
	FILE *fp;
	stu *tmp = head;
	char filename[100];
	printf("\n请输入要保存的文件名:");
	scanf("%s", filename);
	if((fp = fopen(filename, "w+")) == NULL)
	{
		printf("\n打开文件失败!\n");
		exit(0);
	}
	fprintf(fp,"姓名\t学号\t性别\t籍贯\t政治面貌\t手机号\tQQ号\t宿舍\n");
	while(tmp)
	{
//		if(fwrite(tmp, sizeof(stu), 1, fp) != 1)
//			printf("\n保存失败!\n");
        fprintf(fp,"%s\t", tmp->name);
        fprintf(fp,"%s\t", tmp->num);
        fprintf(fp,"%s\t", tmp->sex);
        fprintf(fp,"%s\t", tmp->from);
        fprintf(fp,"%s\t", tmp->political);
        fprintf(fp,"%s\t", tmp->phone);
        fprintf(fp,"%s\t", tmp->QQ);
        fprintf(fp,"%s\n", tmp->dorm);
		tmp = tmp->next;
	}
	printf("\n保存成功!\n");
	fclose(fp);
	system("pause");
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-03 13:17:15  更:2021-12-03 13:18:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 3:10:38-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码