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

簡陋版C語言仿真通訊錄

https://blog.csdn.net/csdn_kou/article/details/80287640

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

給Contact結構體增加一個容量,來表示什么時候增容


#define MAX_NAME 20
typedef struct PeoInfo
{char name[MAX_NAME];int age;char sex[4];
}people;typedef struct Contact
{people * data;int count;int capacity;
}Contact, *pContact;

初始化容量大小,這里我們做小一點可以看到增容效果

/*初始化*/
void InitContact(pContact pc)
{pc->count = 0;pc->capacity = DEFAULT_SZ;pc->data = (people*)calloc(sizeof(people), pc->capacity);
}

檢查是否需要增容放在了增加數據的第一句作為判斷

/*增加數據*/
void check_cap(pContact pc)
{if (pc->count == pc->capacity){people* p = (people *) realloc(pc->data,(pc->capacity+2)*sizeof(people));if (p != NULL){pc->data = p;p = NULL;}pc->capacity += 2;printf("增容成功");}
}

最后別忘了,動態內存開辟空間要釋放

void Free(pContact pc)
{free(pc->data);pc->capacity = 0;pc->count = 0;pc->data = NULL;printf("釋放空間成功\n");
}

完整代碼

main.c

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include "contact.h"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:Free(&my_con);break;case SEARCH:Search(&my_con);break;case SORT:Sort(&my_con);break;default:fflush(stdin);fflush(stdout);//sync();//清除緩沖區//clear();//清除錯誤狀態break;}} while (input);system("pause");return 0;
}

contact.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");
}/*初始化*/
void InitContact(pContact pc)
{pc->count = 0;pc->capacity = DEFAULT_SZ;pc->data = (people*)calloc(sizeof(people), pc->capacity);
}/*增加數據*/
void check_cap(pContact pc)
{if (pc->count == pc->capacity){people* p = (people *) realloc(pc->data,(pc->capacity+2)*sizeof(people));if (p != NULL){pc->data = p;p = NULL;}pc->capacity += 2;printf("增容成功");}
}void AddContact(pContact pc)
{check_cap(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("%-11s %-11s  %-11s \n","姓名","年齡","性別");if (pc->count != 0){for (int i = 0; i < pc->count; i++){if (pc->data[i].age != 0){printf("%d|%-11s %-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];}pc->count - 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  - *(char*)b);
}void Sort(pContact pc)
{int i;qsort(pc->data, pc->count, sizeof(people), compare);for (i = 0; i<pc->count; i++)printf("%d|%-11s %-11d  %-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 (!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;
}void Free(pContact pc)
{free(pc->data);pc->capacity = 0;pc->count = 0;pc->data = NULL;printf("釋放空間成功\n");
}

contact.h

#ifndef __CONTACT_H__
#define __CONTACT_H__#define DEFAULT_SZ 3
/*
這個順序就是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;int count;int capacity;
}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);
void Free(pContact pc);
#endif // !__CONTACT_H__

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

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

相關文章

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…

C語言malloc和calloc的區別

是否對申請的區域進行初始化而已 但是我想你也知道我們寫程序的時候多用malloc而很少用calloc&#xff0c;何解&#xff1f; 因為calloc雖然對內存進行了初始化&#xff08;全部初始化為0&#xff09;&#xff0c;但是同樣也要降低效率的 calloc相當于 p malloc(); memse…

node.js將buffer對象轉換為json對象

d 是buffer對象 let jsstr JSON.stringify(d);let jsondata JSON.parse(jsstr);let buf new Buffer(jsondata);let data buf.toString();sx JSON.parse(data);console.log(sx[peer_count]);詳見百度經驗: https://jingyan.baidu.com/article/8ebacdf079f00549f75cd564.htm…

靜態多態之泛型編程(模板)

起初&#xff0c;我們寫不同類型的加法函數是這樣寫的吧&#xff1a; //Template.h #pragma onceint Add(const int left,const int right) {return leftright; }char Add(const char left,const char right) {return leftright; }float Add(const float left,const float rig…

網站視頻解析 有的url資源放在瀏覽器能直接播放,有的卻不行。

1有的視頻url放在瀏覽器地址欄&#xff0c;回車能直接播放 2.有的視頻url卻直接下載下來一個 很短暫的m3u8文件&#xff0c; 且不能播放 這時候把視頻url放在 vlc 或者專門解析m3u8的網站上卻能直接播放&#xff1a; 例如&#xff1a;https://youku.com-l-youku.com/20190207/2…

【數據結構】布隆過濾器原理詳解及其代碼實現

《博主簡介》 小伙伴們好&#xff0c;我是阿旭。專注于人工智能AI、python、計算機視覺相關分享研究。 ?更多學習資源&#xff0c;可關注公-仲-hao:【阿旭算法與機器學習】&#xff0c;共同學習交流~ &#x1f44d;感謝小伙伴們點贊、關注&#xff01; 《------往期經典推薦--…

c++詳解【繼承】

學過c的人都知道&#xff0c;c的三大特性&#xff1a;封裝、繼承、多態。 我們今天說的是c的繼承&#xff0c;那么為什么要引入繼承&#xff0c;它有什么特點呢&#xff1f; 首先&#xff0c;繼承的特點是&#xff1a;使代碼復用&#xff0c;為后面學習多態做鋪墊。 繼承分為…