C語(yǔ)言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng)
如何用c語(yǔ)言制作簡(jiǎn)易的個(gè)人通訊錄管理系統(tǒng)?想必這是每一位初步學(xué)習(xí)c語(yǔ)言的同學(xué)需要解決的一個(gè)大問(wèn)題。如何將這些數(shù)據(jù)類型不完全相同的數(shù)據(jù)元素存儲(chǔ)并訪問(wèn)呢?采用結(jié)構(gòu)體便能輕松解決這個(gè)問(wèn)題!
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<windows.h>
struct stu //第一部分:聲明結(jié)構(gòu)體類型struct stu
{
char name[100];//姓名為字符串型
int xh;//學(xué)號(hào)為整形
int grade;//年級(jí)
char cel[15];//手機(jī)
char tel[50];//電話
char mail[50];//郵件
char add[100];//地址為字符串型
char post[15];//郵編
struct stu *next;//用指針處理鏈表,next是指針變量,指向結(jié)構(gòu)體變量
};
struct stu *charu(struct stu *head,struct stu *q)//第二部分:插入函數(shù)(插入新結(jié)點(diǎn))
{
struct stu *p;
for(p=head;p->next!=NULL;p=p->next);//for(使p也指向head;當(dāng)p為空文件時(shí) ;p指向下一個(gè)結(jié)點(diǎn))
p->next=q;
q->next=NULL;
return head;
}
void search(struct stu *head) //第三部分:查找結(jié)點(diǎn)并輸出
{
struct stu *p;
int a;//要查找學(xué)生的學(xué)號(hào)
if(head->next==NULL)//頭文件為空時(shí)打印出的結(jié)果為"通訊錄為空"
printf("**********************************通訊錄為空!!!*********************************\n\n\n");
else//頭文件不為空時(shí),開始查詢學(xué)生的信息
{
printf("\t輸入要查詢學(xué)生學(xué)號(hào):");
scanf("%d",&a);
for(p=head->next;p->next!=NULL;p=p->next)//for(使p也指向head;當(dāng)p為空文件時(shí) ;p指向下一個(gè)結(jié)點(diǎn))
{
if(p->xh==a) //如果輸入的學(xué)號(hào)和某個(gè)相同,輸出以下的東西。
{
printf(" 要查找的學(xué)生信息為:\n");
printf(" ★姓名:");puts(p->name);
printf("\t學(xué)號(hào): ");printf("%d",p->xh);
printf("\t年級(jí):");printf("%d\n",p->grade);
printf("\t手機(jī):");puts(p->cel);
printf("\t電話:");puts(p->tel);
printf("\t郵箱:");puts(p->mail);
printf("\t地址");puts(p->add);
printf("\t郵編:");puts(p->post);
printf("\t查找成功!!!");
printf("\n\n\n");
break;
}
}
if(p->xh==a)
{
printf(" 要查找的學(xué)生信息為:\n");
printf(" ★姓名:");puts(p->name);
printf("\t年級(jí):");printf("%d\n",p->grade);
printf("\t手機(jī):");puts(p->cel);
printf("\t電話:");puts(p->tel);
printf("\t郵箱:");puts(p->mail);
printf("\t地址");puts(p->add);
printf("\t郵編:");puts(p->post);
printf("\t查找成功!!!");
printf("\n\n\n");
}
else printf("no people have found!!!\n");//如果不符合,就輸出沒(méi)有找到
}
}
struct stu *del(struct stu *head) //第四部分:刪除結(jié)點(diǎn)
{
struct stu *p,*q;
int a;//要?jiǎng)h除學(xué)生的學(xué)號(hào)
if(head->next==NULL)// 頭文件為空時(shí),輸出通訊錄為空
printf("**********************************通訊錄為空!!!*********************************\n\n\n");
else
{
printf("\t輸入要?jiǎng)h除學(xué)生學(xué)號(hào):");
scanf("%d",&a);
for(p=head,q=p->next;q->xh!=a&&q->next!=NULL;)
{
p=p->next;
q=p->next;
}
if(q->xh==a)
{
p->next=q->next;
free(q);//釋放q,也就是刪除q,在這里就是刪除q(學(xué)號(hào)為a)
printf("刪除成功!!!\n");
}
else printf("no people have found!!!");//如果不符合,就輸出沒(méi)有找到
}
return head;//返回頭文件
}
struct stu *change(struct stu *head) //第五部分:修改結(jié)點(diǎn)內(nèi)容
{
int b,a,c;
struct stu *p;
if(head->next==NULL)// 頭文件為空時(shí),輸出通訊錄為空
printf("**********************************通訊錄為空!!!*********************************\n\n\n");
else
{
printf(" 輸入要修改學(xué)生學(xué)號(hào):");
scanf("%d",&a);
for(p=head->next;p!=NULL;p=p->next)
{
start:printf(" 輸入想要修改什么?\n");
printf("\t\t\t 1:修改姓名\n");
printf("\t\t\t 2:修改學(xué)號(hào)\n");
printf("\t\t\t 3:修改年級(jí)\n");
printf("\t\t\t 4:手機(jī)\n");
printf("\t\t\t 5:電話\n");
printf("\t\t\t 6:郵件\n");
printf("\t\t\t 7:地址\n");
printf("\t\t\t 8:郵編\n");
printf(" 請(qǐng)輸入你的選擇:");
scanf("%d",&b);
switch(b)//先通過(guò)學(xué)號(hào)找到該學(xué)生,然后用switch語(yǔ)句選擇修改項(xiàng),再用switch和goto語(yǔ)句實(shí)現(xiàn)是否循環(huán)
{
case 1:
printf("\t輸入新姓名:");
scanf("%s",p->name);break;
case 2:printf("\t輸入新學(xué)號(hào):");
scanf("%d",&p->xh);break;
case 3:
printf("\t輸入新的年級(jí):");
scanf("%d",&p->grade);break;
case 4:
printf("\t輸入新的手機(jī)號(hào):");
scanf("%s",p->cel);break;
case 5:
printf("\t輸入新的電話號(hào):");
scanf("%s",p->tel);break;
case 6:
printf("\t輸入新的郵箱:");
scanf("%s",p->mail);break;
case 7:
printf("\t輸入新的地址:");
scanf("%s",p->add);break;
case 8:
printf("\t輸入新的郵編;");
scanf("%s",p->post);break;
default: printf("輸入操作錯(cuò)誤,請(qǐng)重新輸入:");
}
printf("修改成功!!!\n");
printf(" 是否要修改其他項(xiàng)? 1:是 2:否\n");
printf(" 請(qǐng)輸入你的選擇:");
scanf("%d",&c);
switch(c) //goto語(yǔ)句實(shí)現(xiàn)是否循環(huán)
{
case 1:goto start;
case 2:break;
}
}
}
return head; //返回頭文件
}
void printall(struct stu *head) //第六部分:輸出全部通訊錄
{
struct stu *p=head->next;
while(1)
{
if(p==NULL)
{
printf("**********************************通訊錄為空!!!*********************************\n\n\n");
break;
}
else if(p->next==NULL)
{
printf(" ★姓名:");puts(p->name);
printf("\t學(xué)號(hào):");printf("%d\n",p->xh);
printf("\t年級(jí):");printf("%d\n",p->grade);
printf("\t手機(jī):");puts(p->cel);
printf("\t電話:");puts(p->tel);
printf("\t郵箱:");puts(p->mail);
printf("\t地址:");puts(p->add);
printf("\t郵編:");puts(p->post);
printf("輸出成功!!!\n");
printf("\n\n\n");
break;
}
else
{
printf(" ★姓名:");puts(p->name);
printf("\t學(xué)號(hào):");printf("%d\n",p->xh);
printf("\t年級(jí):");printf("%d\n",p->grade);
printf("\t手機(jī):");puts(p->cel);
printf("\t電話:");puts(p->tel);
printf("\t郵箱:");puts(p->mail);
printf("\t地址:");puts(p->add);
printf("\t郵編:");puts(p->post);
printf("\n");
p=p->next;
continue;
}
printf("輸出成功!!!\n");
}
}
void sf(struct stu *head) //第八部分:釋放結(jié)點(diǎn)退出系統(tǒng)
{
struct stu *p=head ;
printf("釋放鏈表:\n");
while(p!=NULL)
{
head=head->next;
free(p);
p=head;
}
printf("釋放鏈表成功!!!\n");
}
int main()// 第九部分:主函數(shù)框架
{
int cz;//操作符
struct stu *head,*q;
head=(struct stu*)malloc(sizeof(struct stu));//動(dòng)態(tài)鏈表malloc
head->next=NULL;//使next指向下一個(gè)結(jié)點(diǎn),next結(jié)點(diǎn)不放其他結(jié)點(diǎn)地址
system("color 1e");//修改dos窗口前背景色,用兩個(gè)十六進(jìn)制數(shù)表示
printf("班級(jí): 姓名: 學(xué)號(hào): 設(shè)計(jì)課題:個(gè)人通訊錄管理系統(tǒng)\n");
printf("\n********************************C語(yǔ)言課程設(shè)計(jì)***********************************\n");
printf(" *******************★個(gè)人通訊錄管理系統(tǒng)★*****************\n\n\n");
printf(" * 1:新建通訊錄 *\n");
printf(" * 2:刪除通訊錄 *\n");
printf(" * 3:修改通訊錄 *\n");
printf(" * 4:查詢通訊錄 *\n");
printf(" * 5:顯示全部記錄 *\n");
printf(" * 6:釋放鏈表并結(jié)束程序 *\n");
printf(" *********************************************************\n");
start :printf("輸入操作符1-6:");//"輸入操作符1-
scanf("%d",&cz);
switch(cz)//switch語(yǔ)句
{
case 1:
q=(struct stu *)malloc(sizeof(struct stu));
printf("\t輸入姓名:");scanf("%s",q->name);
printf("\t輸入學(xué)號(hào):");scanf("%d",&q->xh);
printf("\t輸入年級(jí):");scanf("%d",&q->grade);
printf("\t手機(jī)號(hào):");scanf("%s",q->cel);
printf("\t家庭電話:");scanf("%s",q->tel);
printf("\t輸入電子郵件:");scanf("%s",q->mail);
printf("\t通訊錄地址:");scanf("%s",&q->add);
printf("\t輸入郵編:");scanf("%s",&q->post);
charu(head,q);
printf("插入成功!!!\n");break;
case 2://刪除
head=del(head);break;
case 3:
change(head);break;//修改學(xué)生信息
case 4:
search(head);break;//查找結(jié)點(diǎn)head
case 5:
printall(head);break; //保存文件
case 6: //釋放結(jié)點(diǎn)退出系統(tǒng)
sf(head);
exit (0);
default: printf("輸入操作錯(cuò)誤,重新"); //什么也不符合就"輸入操作錯(cuò)誤,重新"
}
goto start;//用goto語(yǔ)句實(shí)現(xiàn)循環(huán)操作
return 0;
}
更多學(xué)習(xí)資料請(qǐng)關(guān)注專題《管理系統(tǒng)開發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的通訊錄
- C語(yǔ)言實(shí)現(xiàn)通訊錄系統(tǒng)
- 用C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易通訊錄
- C語(yǔ)言使用結(jié)構(gòu)體實(shí)現(xiàn)簡(jiǎn)單通訊錄
- C語(yǔ)言實(shí)現(xiàn)通訊錄功能
- C語(yǔ)言通訊錄管理系統(tǒng)完整版
- C語(yǔ)言通訊錄管理系統(tǒng)課程設(shè)計(jì)
- C語(yǔ)言基于哈希表實(shí)現(xiàn)通訊錄
- C語(yǔ)言實(shí)現(xiàn)通訊錄的八種功能(添加、刪除、查找、修改、顯示、排序、退出、清空)
相關(guān)文章
vscode搭建STM32開發(fā)環(huán)境的詳細(xì)過(guò)程
這篇文章主要介紹了vscode搭建STM32開發(fā)環(huán)境的詳細(xì)過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05
C++面向?qū)ο笳Z(yǔ)言自制多級(jí)菜單功能實(shí)現(xiàn)代碼
菜單類主要負(fù)責(zé)菜單的創(chuàng)建、修改、刪除,是包含菜單結(jié)構(gòu)組織和響應(yīng)函數(shù)的模型,用戶擁有充分的自主性,可根據(jù)需要自定義菜單顯示和響應(yīng)函數(shù),這篇文章主要介紹了C++面向?qū)ο笳Z(yǔ)言自制多級(jí)菜單,需要的朋友可以參考下2024-06-06
visual studio code 配置C++開發(fā)環(huán)境的教程詳解 (windows 開發(fā)環(huán)境)
這篇文章主要介紹了 windows 開發(fā)環(huán)境下visual studio code 配置C++開發(fā)環(huán)境的圖文教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03
C++類重載函數(shù)的function和bind使用示例
這篇文章主要介紹了C++類重載函數(shù)的function和bind使用示例,幫助大家更好的理解和使用c++,感興趣的朋友可以了解下2021-01-01
C語(yǔ)言靜態(tài)鏈表和動(dòng)態(tài)鏈表
靜態(tài)鏈表和動(dòng)態(tài)鏈表是線性表鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)的兩種不同的表示方式。靜態(tài)鏈表的初始長(zhǎng)度一般是固定的,在做插入和刪除操作時(shí)不需要移動(dòng)元素,僅需修改指針。動(dòng)態(tài)鏈表是相對(duì)于靜態(tài)鏈表而言的,一般地,在描述線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)時(shí)如果沒(méi)有特別說(shuō)明即默認(rèn)描述的是動(dòng)態(tài)鏈表。2016-05-05

