您好,登錄后才能下訂單哦!
1、問題:將指針數(shù)組和二維數(shù)組中的字符串存放到第三個(gè)指針?biāo)赶虻膬?nèi)存空間中,并進(jìn)行排序(默認(rèn)升序)輸出,必須通過函數(shù)來完成。
(1)、代碼如下:#include<stdio.h> #include<string.h> #include<malloc.h> void destorySpace_2(char ***p3, int len3); void destorySpace_1(char **p3, int len3); int sort(char **myp1, int len1, char (*myp2)[30], int len2, char ***myp3, int *len3); int sort(char **myp1, int len1, char (*myp2)[30], int len2, char ***myp3, int *len3){ int len; int i; int j; char **p3 = NULL; int temLen; char *tmp1; len = len1 + len2; p3 = (char **)malloc(sizeof(char *) * len); //先將第一個(gè)指針數(shù)組的內(nèi)容拷貝到p3所指向的空間中 for(i = 0; i < len1; i++){ temLen = strlen(myp1[i])+1; p3[i] = (char *)malloc(sizeof(char) * temLen); strcpy(p3[i], myp1[i]); } //先將第二個(gè)二維數(shù)組的內(nèi)容拷貝到p3所指向的空間中 for(j = 0; j < len2; j++, i++){ temLen = strlen(myp2[j])+1; p3[i] = (char *)malloc(sizeof(char) * temLen); strcpy(p3[i], myp2[j]); } //最后對(duì)p3所指向的空間的字符串在進(jìn)行排序; for(i = 0; i < len; i++){ for(j = i+1; j < len; j++){ if(strcmp(p3[i], p3[j]) > 0){ tmp1 = p3[i]; p3[i] = p3[j]; p3[j] = tmp1; } } } *myp3 = p3; *len3 = len; return 0; } //銷毀p3所指向空間的第一種方法,自己必須在調(diào)用下面對(duì)p3 = NULL; void destorySpace_1(char **p3, int len3){ int i; if(p3 != NULL){ for(i = 0; i < len3; i++){ if(p3[i] != NULL){ free(p3[i]); } } free(p3); } } //銷毀p3所指向空間的第二種方法 void destorySpace_2(char ***p3, int len3){ int i; char **p; if(p3 == NULL){ return; } p = *p3; if(p != NULL){ for(i = 0; i < len3; i++){ if(p[i] != NULL){ free(p[i]); } } free(p); *p3 = NULL; } } int main(void){ char *p1[] = {"aaaaa", "bbbbb", "ccccc", "eeeeeee"}; char buf1[][30] = {"fffff", "kkkkkkk"}; char **p3; int len1; int len2; int len3; int ret; int i; len1 = sizeof(p1)/sizeof(p1[0]); len2 = sizeof(buf1)/sizeof(buf1[0]); ret = sort(p1, len1, buf1, len2, &p3, &len3); if(ret != 0){ printf("sort() err\n"); return ret; } for(i = 0; i < len3; i++){ printf("%s\n", p3[i]); } //destorySpace_2(&p3, len3); destorySpace_1(p3, len3); p3 = NULL; return 0; }
(2)、運(yùn)行結(jié)果:
(3)、模型分析
思想:因?yàn)橐煤瘮?shù)完成,對(duì)二維數(shù)組和指針數(shù)組中的字符串先進(jìn)行存放到p3所指向的空間中,就必須的使用三級(jí)指針來接收了,然后在對(duì)其所指向的空間進(jìn)行排序!
在進(jìn)行空間的釋放時(shí),要是在函數(shù)內(nèi)部避免野指針問題,就必須的用三級(jí)指針來接收了!
在進(jìn)行空間的釋放時(shí),要是用二級(jí)指針來接收的話,則自己必須在調(diào)用的下面對(duì)其進(jìn)行賦空,避免野指針的出現(xiàn),原因:2個(gè)指針空間的值沒有半毛錢的關(guān)系(它們之間僅僅是形參、實(shí)參的對(duì)應(yīng)關(guān)系)?。?!
拋出問題的代碼:
//函數(shù)調(diào)用 destorySpace(char **p3){ ...... p3 = NULL; } //主函數(shù) int main(void){ char **p3 = NULL; ... destorySpace(p3); }
模型如下:
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。