簡陋版C語言仿真通訊錄

文件cotact.c

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include "contact.h"
/*初始化*/
void InitContact(pContact pc)
{pc->count = 0;memset(pc->data, 0, sizeof(pc->data));
}/*增加數據*/
void AddContact(pContact pc)
{if (pc->count < 1000){printf("請輸入名字>");scanf("%s", pc->data[pc->count].name);printf("請輸入年齡>");scanf("%d", &pc->data[pc->count].age);printf("請輸入性別>");scanf("%s", pc->data[pc->count].sex);pc->count++;}else{printf("存不下了");return;}
}/*展示*/
void ShowContact(pContact pc)
{printf("姓名:             年齡:     性別:\n");if (pc->count != 0){for (int i = 0; i < pc->count; i++){if (pc->data[i].age != 0){printf("%d|%-8s%11d%11s\n", i,pc->data[i].name,pc->data[i].age,pc->data[i].sex);}}}else{printf("通訊沒有號碼\n");return;}
}/*刪除*/
void DelContact(pContact pc)
{printf("請輸入要刪除的編號");int i = 0,num;scanf("%d", &num);for (i = num; i < pc->count; i++){pc->data[i] =  pc->data[i +1];}
}/*判斷輸入的名字是不是重復,如果重復就刪除*/
void justice(pContact pc)
{for (int i = 0; i < pc->count-1; i++){if(!strcmp(pc->data[pc->count - 1].name , pc->data[i].name)){printf("\n非法輸入\n");pc->data[pc->count -1] = pc->data[pc->count];}}
}/*比較*/
char compare(const void * a, const void * b)
{return (*(char*)a+1 - *(char*)b);
}void Sort(pContact pc)
{int i;qsort (pc, pc->count, sizeof(people), compare);for (i=0; i<pc->count;i++)printf("%d|%-8s%8d%11s\n", i,pc->data[i].name, pc->data[i].age, pc->data[i].sex);return;
}/*查找*/
int search_son(pContact pc,char *name)
{int i, j;for (i = 0; i < pc->count; i++){//if (name == pc->data->name[i])//這樣的比較不行,if (!strcmp(name, pc->data[i].name)){return i;}}return -1;
}
void Search(pContact pc)
{int i = 0;char name[20];//要給一個大小,要不然一直讀取位置時發生訪問沖突printf("name>");scanf("%s", &name);i = search_son(pc,name);if (i >= 0){printf("找到了,嗚啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦!\n");printf("%d|%-8s%8d%11s\n",i,pc->data[i].name,pc->data[i].age,pc->data[i].sex);printf("******************************************\n");}else{printf("Can't find it\n");}return;
}

main.c

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include "contact.h"void menu()
{printf("*************************\n");printf("**1.add     2.show*******\n");printf("**3.search  4.delete*****\n");printf("**5.sort    0.exit*******\n");printf("*************************\n");
}int main()
{int input = 0;Contact my_con;InitContact(&my_con);do {menu();printf("please chose");scanf("%d", &input);//運行第二遍是輸入字母默認為1switch (input){case ADD:AddContact(&my_con);justice(&my_con);break;case SHOW:ShowContact(&my_con);break;case DEL:DelContact(&my_con);break;case EXIT:break;case SEARCH:Search(&my_con);break;case SORT:Sort(&my_con);break;default :fflush(stdin);fflush(stdout);break;}} while (input);system("pause");return 0;
}

contact.h

#ifndef __CONTACT_H__
#define __CONTACT_H__/*
這個順序就是switch()的順序,注意逗號不是分號,最后一個不寫符號
*/
enum OPTION
{EXIT,ADD,SHOW,SEARCH,DEL,SORT
};#define MAX_NAME 20
typedef struct PeoInfo
{char name[MAX_NAME];int age;char sex[4];
}people;typedef struct Contact
{people data[1000];int count;
}Contact,*pContact;void AddContact(pContact pc);
void InitContact(pContact pc);
void ShowContact(pContact pc);
void DelContact(pContact pc);
void justice(pContact pc);
void Search(pContact pc);
void Sort(pContact pc);
#endif // !__CONTACT_H__

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382837.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382837.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382837.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

pip3 便捷安裝包

將虛擬環境下 的包列舉出來 并保存到文件夾 pip3 freeze > requirments.txt 一次性安裝文件里面所列舉的所有的包 pip3 install -r requirments.txt

有趣的約瑟夫環問題

大家有沒有聽過約瑟夫環這個問題呢&#xff1f;我們先來看看它是一個什么樣的問題~ 約瑟夫環&#xff08;Josephus&#xff09;問題是由古羅馬的史學家約瑟夫&#xff08;Flavius Josephus&#xff09;提出的。該問題的說法不一&#xff0c;傳說他參加并記錄了公元66—70年猶太…

C語言模擬實現標準庫函數之qsort() 2

C語言模擬實現標準庫函數之qsort() <1> https://blog.csdn.net/csdn_kou/article/details/80158194 排序數字 int int_cmp(const void *elem1, const void *elem2) { return *(int *)elem1 - *(int *)elem2; }int main() { int arr[] { 9,8,7,6,5,4,3,2,1 }; int siz…

node.js windows下安裝與配置

轉自 https://www.cnblogs.com/liuqiyun/p/8133904.html

一系列鏈表題

1、鏈表的倒序輸出&#xff1a;(輸出4&#xff0c;3&#xff0c;2&#xff0c;1)在這里&#xff0c;可以使用遞歸的方式&#xff1a; <span style"font-size:18px;">void Reverse(pNode pHead) {if(pHead){Reverse(pHead->next);cout<<pHead->data…

簡陋版C語言仿真通訊錄之動態內存開辟版本

簡陋版C語言仿真通訊錄 https://blog.csdn.net/csdn_kou/article/details/80287640 簡陋版C語言仿真通訊錄之動態內存開辟版本 給Contact結構體增加一個容量&#xff0c;來表示什么時候增容 #define MAX_NAME 20 typedef struct PeoInfo {char name[MAX_NAME];int age;char …

node.js 代碼修改 自動識別重啟工具

npm install supervisor -g supervisor xx.js 代替 node xx.js 能實現自動重啟服務&#xff0c;識別代碼更新

C語言轉移表之加減乘除無限進化版

主干程序初級版本進階版本版本進化 主干程序 輸入程序解析程序 /*解析字符串 有空格把空格分開 比如輸入&#xff1a;add 1 2 解析后&#xff1a;add12*/ void do_parse(char *buf) {int state 0;int i 0;int argc 0;char *argv[8] {0};for (i 0; buf[i]; i){if (state …

node.js 筆記1 模塊方面

url 模塊 parse 解析url 可以用來獲取查詢參數 xx.js exports.xx xx 另一個文件引用 require(’./xx.js); 獲取的句柄 相當于 xx.js 中的 exports xx.js module.exports xx 這樣被人引用 相當于就是直接拿到了 xx 當require xx 的時候&#xff0c; 如果xx不在當前文件夾 &…

c++之指針引用

指針&#xff1a;指向一塊內存地址的標識。 引用&#xff1a;給已經定義的變量起的別名。 格式&#xff1a; 類型 &引用變量名 已定義的變量名&#xff08;引用變量名和已定義的變量名可以看成是同一個實體&#xff0c;一個改變&#xff0c;另一個也隨之改變&#xff0…

C語言之scanf中的格式

scanf函數原型控制格式1.%[^\n]%*c例子1例子2 1.%[]例子1例子2 scanf函數原型 int scanf( const char *format, ... ); 見可變參數求和 https://blog.csdn.net/csdn_kou/article/details/79996606 控制格式 %c 一個單一的字符 %d 一個十進制整數 %i 一個整數 %e, %f, %…

node.js 將文件目錄讀取 通過匿名函數自執行 將異步改為同步

var fs require(fs);var filesarray []; fs.readdir(html, function(error, files){if(error){console.log(error.stack);console.log(--------);console.log(文件夾讀取失敗);return false;}// 匿名函數自執行&#xff0c; 將異步改為同步(function getFile(i){console.log(…

蛇形數組打印(兩種形式)

#蛇形數組打印 ##第一種形式 形式1 51 2 3 4 516 17 18 19 615 24 25 20 714 23 22 21 813 12 11 10 9 請按任意鍵繼續. . .形式2 513 14 15 16 112 23 24 17 211 22 25 18 310 21 20 19…

node.js 獲取異步方法里面的數據 =》 兩種方式

第一種&#xff1a; 通過回調函數實現&#xff1a; var fs require(fs); function getmime(callback){ fs.readFile(./t1.js, function(err, data){// 現在理解&#xff0c;異步方法里還有別的引用 就不會提前釋放callback(data);}); }getmime(function(data){console.log(…

python入門--基本語法

標準數據類型&#xff1a;Number(數字)&#xff0c;String(字符串)&#xff0c;List(列表)&#xff0c;Tuple(元組)&#xff0c;Sets(集合)&#xff0c;Dictionary(字典)Number只支持int(表示長整型)&#xff0c;float&#xff0c;bool&#xff0c;complex&#xff08;復數&…

Linux網站大雜燴《自己查閱》

從網絡上拷貝別人歸納的列表。 Linux優秀網站列表 國內 http://www.chinaunix.net/ 國內最火爆的unix/linux論壇 http://www.linuxforum.net/ linux愛好者交流的場所&#xff0c;側重編程開發 http://www.linuxaid.com.cn/ 面向初學者者提供資料 http://www.ibm.com/de…

python之條件、循環語句

其實&#xff0c;很多語言的語法都是相通的&#xff0c;包括初學python一樣。 今天要說的是條件、循環語句。這部分也是相對比較簡單的&#xff0c;就python而言&#xff0c;只是書寫方式稍作改動罷了。 1、條件語句 &#xff08;1&#xff09;格式&#xff1a; if 判斷條件…

node.js Promise簡單介紹

轉自百度&#xff1a; https://baijiahao.baidu.com/s?id1589455136001194151&wfrspider&forpc

數據結構之空間復雜度和空間復雜度

1.空間復雜度計算方法 2.時間復雜度計算方法非遞歸遞歸情況遞歸總次數*每次遞歸次數 1.空間復雜度 空間復雜度是指 執行這個算法所需要的內存空間。空間復雜度是函數中創建對象的個數關于問題規模函數表達式&#xff0c;一般情況下用O漸進表示法表示 計算方法 1.忽略常數&…

node.js 獲取異步方法里面數據 的方式

第一種 使用回調函數&#xff1a; function getData(callback){setTimeout(function(){var name xxxx;callback(name);}, 1000); }// 外部獲取異步方法里面的數據 采用回調函數的方式 getData(function(data){console.log(name); });第二種方式 事件觸發&#xff1a; var fs…