C語言實(shí)現(xiàn)簡易通訊錄功能
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)簡易通訊錄的具體代碼,供大家參考,具體內(nèi)容如下
這兩天用C語言編寫了一個(gè)簡易版通訊錄(學(xué)生信息管理) ,大致功能有添加信息,查看信息(自動(dòng)按姓名排序,printf輸出帶顏色字體),查找信息(按姓名查找),刪除信息(輸入姓名刪除相關(guān)信息),修改信息(輸入修改人的名字,可選擇修改其任意信息)和退出 。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define SIZE 100
typedef struct student STU;
int person = 0;
struct student
{
char name[10];
int num;
int age;
};
void welcome()
{
system("clear");
printf("\n\n\n\n\t\t\t========================================");
printf("\n\n\t\t\t\t\tWelcome!\n");
sleep(3);
}
void menu()
{
system("clear");
printf("\n\n\t************************************************************************");
printf("\n\t\t\t\t\t請(qǐng)選擇:");
printf("\n\t\t\t\t\t1.添加信息");
printf("\n\t\t\t\t\t2.查看信息");
printf("\n\t\t\t\t\t3.查找信息");
printf("\n\t\t\t\t\t4.刪除信息");
printf("\n\t\t\t\t\t5.修改信息");
printf("\n\t\t\t\t\t6.退出");
printf("\n\t************************************************************************");
}
/*添加信息*/
void AddInfo(STU *s[])
{
system("clear");
printf("姓名 學(xué)號(hào) 年齡\n");
printf("------------------------\n");
printf("請(qǐng)輸入信息:(bye結(jié)束添加)\n");
while(1)
{
s[person] = (STU*)malloc(sizeof(STU));
if(NULL == s[person])
{
printf("malloc failure!\n");
}
scanf("%s", s[person]->name);
if(!strcmp(s[person]->name, "bye"))
{
break;
}
scanf("%d%d", &s[person]->num, &s[person]->age);
getchar();
person++;
}
}
/*查看信息(按姓名排序)*/
void ShowAll(STU *s[])
{
system("clear");
int i, j;
STU *q[1] = {0};
q[0] = (STU *)malloc(sizeof(STU));
printf("information:\n");
for(i = 0; i < person; i++)
{
for(j = 0; j < person - 1 - i; j++)
{
if(strcmp(s[j]->name, s[j + 1]->name) > 0)
{
q[0] = s[j];
s[j] = s[j + 1];
s[j + 1] = q[0];
}
}
}
for(i = 0; i < person; i++)
{
printf("\e[1;35mname:%s, num:%d, age:%d\e[0m\n", s[i]->name, s[i]->num, s[i]->age);
}
sleep(3);
getchar();
}
/*查找信息*/
void Search_name(char *name, STU *s[])
{
int i, n = 0;
for(i = 0; i < person; i++)
{
if(strcmp(name, s[i]->name) == 0)
{
n++;
printf("name:%s, num:%d, age:%d\n", s[i]->name, s[i]->num, s[i]->age);
}
}
if(n == 0)
{
printf("不存在!\n");
}
}
void SearchInfo(STU *s[])
{
system("clear");
char *name = (char *)malloc(sizeof(char));
printf("請(qǐng)輸入要查找的人的名字:\n");
scanf("%s", name);
Search_name(name, s);
}
/*刪除信息*/
void DeleteInfo(STU *s[])
{
system("clear");
int i, n = 0, j;
char del_name[10];
printf("請(qǐng)輸入要?jiǎng)h除的人的名字:\n");
scanf("%s", del_name);
getchar();
getchar();
for(i = 0; i < person; i++)
{
if(strcmp(del_name, s[i]->name) == 0)
{
n++;
free(s[i]);
for(j = i; j < person - 1; j++)
{
strcpy(s[j]->name, s[j + 1]->name);
s[j]->num = s[j + 1]->num;
s[j]->age = s[j + 1]->age;
}
person--;
}
}
if(n == 0)
{
printf("要?jiǎng)h除的人不存在!\n");
}
else
{
printf("刪除成功!\n");
}
}
/*修改信息*/
void Change_name(char *name, STU *s[])
{
int i, n = 0, choice;
char *new_name = (char *)malloc(sizeof(char));
int new_num, new_age;
for(i = 0; i < person; i++)
{
if(strcmp(name, s[i]->name) == 0)
{
n++;
printf("該學(xué)生的信息如下:");
printf("name:%s, num:%d, age:%d\n", s[i]->name, s[i]->num, s[i]->age);
printf("----------------------------\n");
printf("請(qǐng)選擇要修改的內(nèi)容(1.name 2.num 3.age):\n");
scanf("%d", &choice);
switch(choice)
{
case 1:
printf("請(qǐng)輸入新的名字:\n");
scanf("%s", new_name);
strcpy(s[i]->name, new_name);
break;
case 2:
printf("請(qǐng)輸入新的學(xué)號(hào):\n");
scanf("%d", &new_num);
s[i]->num = new_num;
break;
case 3:
printf("請(qǐng)輸入新的年齡:\n");
scanf("%d", &new_age);
s[i]->age = new_age;
break;
}
}
}
if(n == 0)
{
printf("不存在!\n");
}
}
void ChangeInfo(STU *s[])
{
system("clear");
char *name = (char *)malloc(sizeof(char));
printf("請(qǐng)輸入要修改的人的名字:\n");
scanf("%s", name);
Change_name(name, s);
}
int main()
{
struct student *s[SIZE] = {0};
int choice;
welcome();
while(1)
{
menu();
printf("\nPlease input choice:");
scanf("%d", &choice);
switch(choice)
{
case 1:
AddInfo(s);
break;
case 2:
ShowAll(s);
break;
case 3:
SearchInfo(s);
break;
case 4:
DeleteInfo(s);
break;
case 5:
ChangeInfo(s);
break;
case 6:
exit(0);
break;
}
}
return 0;
}
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
深入解析Radix Sort基數(shù)排序算法思想及C語言實(shí)現(xiàn)示例
基數(shù)排序和桶排序、計(jì)數(shù)排序共同是三種最常用的線性排序算法,這里我們就來深入解析Radix Sort基數(shù)排序算法思想及C語言實(shí)現(xiàn)示例,需要的朋友可以參考下2016-07-07
CMake語法及CMakeList.txt簡單使用小結(jié)
Cmake主要用于開發(fā)跨平臺(tái)的C++項(xiàng)目,本文主要介紹了CMake語法及CMakeList.txt簡單使用小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2022-05-05
C/C++判斷傳入的UTC時(shí)間是否當(dāng)天的實(shí)現(xiàn)方法
在項(xiàng)目中經(jīng)常會(huì)顯示一個(gè)時(shí)間,如果這個(gè)時(shí)間在今日內(nèi)就顯示為時(shí)分秒,否則顯示為年月日,有需要的朋友可以參考一下2014-01-01
C++設(shè)計(jì)模式中控制反轉(zhuǎn)與依賴注入淺析
這篇文章主要介紹了C++設(shè)計(jì)模式中控制反轉(zhuǎn)與依賴注入,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
C/C++之long int與long long的區(qū)別及說明
這篇文章主要介紹了C/C++之long int與long long的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
C語言實(shí)現(xiàn)飛機(jī)票務(wù)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)飛機(jī)票務(wù)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
C語言用指針函數(shù)尋找數(shù)組中的最大值與次大值
這篇文章主要給大家介紹了關(guān)于C語言用指針函數(shù)尋找數(shù)組中的最大值與次大值的相關(guān)資料,該代碼通過定義一個(gè)名為LargestTow的函數(shù)來找出數(shù)組中的最大值和次大值,并將結(jié)果分別存入指針?biāo)赶虻膬?nèi)存單元中,需要的朋友可以參考下2024-11-11

