堆中分配二维数组初始化排序

方法一:

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int getmem(char *** parry,int *depth,int *len){

复制代码
int mydepth = *depth;
int mylen = *len;
char ** myarry = (char **)malloc(mydepth*sizeof(char*));
for(int i=0;i<mydepth;i++) {
    myarry[i] = (char *)malloc(mylen*sizeof(char));
}
*parry = myarry;
return 0;

}

int sortArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

char temp[mylen];

复制代码
for(int i = 0;i<mydepth;i++) {
    for(int j=i+1;j<mydepth;j++)
        if(strcmp(arry[i],arry[j])>0) {
            strcpy(temp,arry[i]);
            strcpy(arry[i],arry[j]);
            strcpy(arry[j],temp);
        }
}
return 0;

}

int sortArry1(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

char *temp;

复制代码
for(int i = 0;i<mydepth;i++) {
    for(int j=i+1;j<mydepth;j++)
        if(strcmp(arry[i],arry[j])<0) {
            char * temp = arry[i];
            arry[i] = arry[j];
            arry[j] = temp;
        }
}
return 0;

}

int initArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

复制代码
for(int i=0;i<mydepth;i++) {
    strcpy(arry[i],"aaaaaaaa");
}
strcpy(arry[1],"cccccccc");
strcpy(arry[3],"bbbbbbbb");

return 0;

}

int printArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

for(int i=0;i<mydepth;i++) {

printf("%s\n",arry[i]);

}

printf("------------------------------\n");

return 0;

}

int freeArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

复制代码
if(arry != NULL) {    
    for(int i=0;i<mydepth;i++) {
        if(arry[i] !=NULL ) {
            free(arry[i]);
        }
    }
    free(arry);
}

return 0;

}

int freeArry1(char *** marry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

char ** arry = *marry;

if(arry != NULL) {

for(int i=0;i<mydepth;i++) {

if(arry[i] !=NULL ) {

free(arry[i]);

}

}

free(arry);

}

marry = NULL;

return 0;

}

int freeArry2(char *** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

复制代码
if(arry != NULL) {    
    for(int i=0;i<mydepth;i++) {
        if((*arry)[i] !=NULL ) {
            free((*arry)[i]);
        }
    }
    free(*arry);
}
arry = NULL;
return 0;

}

int main(){

复制代码
int depth = 5;
int len = 100;
char ** arry = NULL;
getmem(&arry,&depth,&len);
initArry(arry,&depth,&len);
printArry(arry,&depth,&len);

sortArry(arry,&depth,&len);
printArry(arry,&depth,&len);

sortArry1(arry,&depth,&len);
printArry(arry,&depth,&len);

//freeArry(arry,&depth,&len);
//freeArry1(&arry,&depth,&len);
freeArry2(&arry,&depth,&len);
return 0;

}

方法二:

多分配一个数组,把最后一个数组置为0,作为循环判断条件。

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int getmem(char *** parry,int *depth,int *len){

复制代码
int mydepth = *depth+1;
int mylen = *len;
char ** myarry = (char **)malloc(mydepth*sizeof(char*));
for(int i=0;i<mydepth;i++) {
    myarry[i] = (char *)malloc(mylen*sizeof(char));
}
*parry = myarry;
return 0;

}

int sortArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

char temp[mylen];

复制代码
for(int i = 0;arry[i]!=0;i++) {
    for(int j=i+1;arry[j]!=0;j++)
        if(strcmp(arry[i],arry[j])>0) {
            strcpy(temp,arry[i]);
            strcpy(arry[i],arry[j]);
            strcpy(arry[j],temp);
        }
}
return 0;

}

int sortArry1(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

char *temp;

复制代码
for(int i = 0;arry[i]!=0;i++) {
    for(int j=i+1;arry[j]!=0;j++)
        if(strcmp(arry[i],arry[j])<0) {
            char * temp = arry[i];
            arry[i] = arry[j];
            arry[j] = temp;
        }
}
return 0;

}

int initArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

int i=0;

for(i=0;i<mydepth;i++) {

strcpy(arry[i],"aaaaaaaa");

}

strcpy(arry[1],"cccccccc");

strcpy(arry[3],"bbbbbbbb");

arry[i]=0;

复制代码
return 0;

}

int printArry(char ** arry,int *depth,int *len){

int mydepth = *depth;

int mylen = *len;

for(int i=0;arry[i]!=0;i++) {

printf("%s\n",arry[i]);

}

printf("------------------------------\n");

return 0;

}

int freeArry(char ** arry,int *depth,int *len){

int mydepth = *depth+1;

int mylen = *len;

复制代码
if(arry != NULL) {    
    for(int i=0;arry[i]!=0;i++) {
        if(arry[i] !=NULL ) {
            free(arry[i]);
            arry[i]=NULL;
        }
    }
    free(arry);
    arry=NULL;//把形参置空
}

return 0;

}

int freeArry1(char *** marry,int *depth,int *len){

int mydepth = *depth+1;

int mylen = *len;

char ** arry = *marry;

if(arry != NULL) {

for(int i=0;arry[i]!=0;i++) {

if(arry[i] !=NULL ) {

free(arry[i]);

arry[i]=NULL;

}

}

free(arry);//把形参置空

arry=NULL;

}

marry = NULL;//把实参也置空

return 0;

}

int freeArry2(char *** arry,int *depth,int *len){

int mydepth = *depth+1;

int mylen = *len;

复制代码
if((*arry) != NULL) {    
    for(int i=0;i<mydepth;i++) {
        if((*arry)[i] !=NULL ) {
            free((*arry)[i]);
            (*arry)[i]=NULL;
        }
    }
    free(*arry);
    *arry=NULL;//把形参置空
}
arry = NULL;//把实参也置空
return 0;

}

int main(){

复制代码
int depth = 8;
int len = 100;
char ** arry = NULL;
getmem(&arry,&depth,&len);
initArry(arry,&depth,&len);
printArry(arry,&depth,&len);

sortArry(arry,&depth,&len);
printArry(arry,&depth,&len);

sortArry1(arry,&depth,&len);
printArry(arry,&depth,&len);

freeArry(arry,&depth,&len);
arry = NULL;//把实参也置空
freeArry1(&arry,&depth,&len);
freeArry2(&arry,&depth,&len);
return 0;

}

相关推荐
一只拉古4 分钟前
掌握贪心(Greedy)算法:从 LeetCode 难题到系统架构
算法·leetcode·面试
xrkhy1 小时前
提高课:数据结构之树状数组
数据结构·c++·算法
阳洞洞2 小时前
leetcode 2787. Ways to Express an Integer as Sum of Powers
算法·leetcode·动态规划·01背包问题
阳洞洞2 小时前
leetcode 279. Perfect Squares
算法·leetcode·动态规划·完全背包问题
星语心愿.2 小时前
Y1——ST表
c++·算法
新生农民2 小时前
最小覆盖子串
java·数据结构·算法
烁3473 小时前
每日一题(小白)暴力娱乐篇22
java·开发语言·算法·娱乐
rigidwill6663 小时前
华为机试—最大最小路
数据结构·c++·算法·华为od·华为·职场和发展·并查集
鑫—萍4 小时前
数据结构与算法——链表OJ题详解(2)
c语言·开发语言·数据结构·学习·算法·链表
努力学习的小廉4 小时前
我爱学算法之——滑动窗口攻克子数组和子串难题(下)
c++·算法