二级指针内存模型(三)

自定义内存,使用堆中分配内存来控制数据交换

交换指针指向的内容

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

int main()
{
    char **p2 = NULL;
    int i,j;
    int num = 5;
    p2 = (char **)malloc(sizeof(char *) * num);

    for(i = 0; i < num; i++)
    {
        p2[i] = (char *)malloc(sizeof(char) * 100);
        sprintf(p2[i],"%d%d%d",i+1,i+1,i+1);
    }        

    //print
    printf("before sort\n");
    for(i = 0; i < num; i++)
    {
        printf("%s \n",p2[i]);
    }

    char *tmp = NULL;
    //sort
    for(i = 0; i < num; i++)
    {
        for(j = i+1; j < num; j++)
        {
            if(strcmp(p2[i],p2[j]) < 0)
            {
                tmp = p2[i];
                p2[i] = p2[j];
                p2[j] = tmp;
            }
        }
    }

    printf("after sort\n");
    for(i = 0; i < num; i++)
    {
        printf("%s \n",p2[i]);
    }

    //free
    for(i = 0; i < num; i++)
    {
        if(p2[i] != NULL)
        {
            free(p2[i]);
            p2[i] = NULL;
        }
    }

    if(p2 != NULL)
    {
        free(p2);
    }
    return 0;
}

交换指针指向的内存块

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

int main()
{
    char **p2 = NULL;
    int i,j;
    int num = 5;
    char tmpbuf[100];
    p2 = (char **)malloc(sizeof(char *) * num);

    for(i = 0; i < num; i++)
    {
        p2[i] = (char *)malloc(sizeof(char) * 100);
        sprintf(p2[i],"%d%d%d",i+1,i+1,i+1);
    }        

    //print
    printf("before sort\n");
    for(i = 0; i < num; i++)
    {
        printf("%s \n",p2[i]);
    }

    char *tmp = NULL;
    //sort change the storage
    for(i = 0; i < num; i++)
    {
        for(j = i+1; j < num; j++)
        {
            if(strcmp(p2[i],p2[j]) < 0)
            {
                strcpy(tmpbuf,p2[i]);
                strcpy(p2[i],p2[j]);
                strcpy(p2[j],tmpbuf);
            }
        }
    }

    printf("after sort\n");
    for(i = 0; i < num; i++)
    {
        printf("%s \n",p2[i]);
    }

    //free
    for(i = 0; i < num; i++)
    {
        if(p2[i] != NULL)
        {
            free(p2[i]);
            p2[i] = NULL;
        }
    }

    if(p2 != NULL)
    {
        free(p2);
    }
    return 0;
}

函数封装接口

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

char **getMem(int num)
{
    char **p2 = NULL;
    int i;
    p2 = (char **)malloc(sizeof(char *) * num);
    if(p2 == NULL)
    {
        return NULL;
    }

    for(i = 0; i < num; i++)
    {
        p2[i] = (char *)malloc(sizeof(char) * 100);
        sprintf(p2[i],"%d%d%d",i+1,i+1,i+1);
    }        

    return p2;
}

void sortMyarray(char **myArray,int num)
{
     int i = 0,j = 0;
    char *tmp = NULL;
    //sort change the storage
    for(i = 0; i < num; i++)
    {
        for(j = i; j < num; j++)
        {
            if(strcmp(myArray[i],myArray[j]) < 0)
            {
                tmp = myArray[i];
                myArray[i] = myArray[j];
                myArray[j] = tmp;
            }
        }
    }
}

void printMyArray(char **myArray,int num)
{
    int i = 0;
    for(i = 0; i < num; i++)
    {
        printf("%s \n",*(myArray+i));
    }
}

void getMem_free(char **p2,int num)
{
    int i;
    for(i = 0; i < num; i++)
    {
        if(p2[i] != NULL)
        {
            free(p2[i]);
            p2[i] = NULL;
        }
    }

    if(p2 != NULL)
    {
        free(p2);
    }
}

int main()
{
    char **p2 = NULL;
    int i,j;
    int num = 5;
    char tmpbuf[100];

    p2 = getMem(num);
    //print
    printf("before sort\n");
    printMyArray(p2,num);

    sortMyarray(p2,num);

    printf("after sort\n");
    printMyArray(p2,num);

    //free
    getMem_free(p2,num);

    return 0;
}

#include<stdio.h>

#include<string.h>

#include<stdlib.h>

int main()

{

char
**p2 = NULL;

int
i,j;

int
num = 5;

p2
= (char **)malloc(sizeof(char *) * num);

for(i
= 0; i < num; i++)

{

p2[i]
= (char *)malloc(sizeof(char) * 100);

sprintf(p2[i],"%d%d%d",i+1,i+1,i+1);

}

//print

printf("before
sort\n");

for(i
= 0; i < num; i++)

{

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

}

char
*tmp = NULL;

//sort

for(i
= 0; i < num; i++)

{

for(j
= i+1; j < num; j++)

{

if(strcmp(p2[i],p2[j])
< 0)

{

tmp
= p2[i];

p2[i] = p2[j];

p2[j]
= tmp;

}

}

}

printf("after
sort\n");

for(i
= 0; i < num; i++)

{

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

}

//free

for(i
= 0; i < num; i++)

{

if(p2[i]
!= NULL)

{

free(p2[i]);

p2[i]
= NULL;

}

}

if(p2
!= NULL)

{

free(p2);

}

return
0;

}

原文地址:https://www.cnblogs.com/wanghao-boke/p/11625376.html

时间: 2024-10-29 19:10:00

二级指针内存模型(三)的相关文章

C二级指针内存模型三

#include <stdio.h> #include <stdlib.h> #include <string.h> /* 二级指针的第三种内存模型 */ //打印字符串数组 int printArray(char **arrayStr,int num) {     int i = 0;     for (i=0; i<num; i++)     {         printf("%s \n",arrayStr[i]);     }     

C语言 二级指针内存模型混合实战

//二级指针内存模型混合实战 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <string.h> //将内存模型①和内存模型②的数据拷贝到内存模型③ char ** threemodel(char **pin1,int num1,char (*pin2)[20],int num2,char **pin3,int *pnum3){ if (pin1==NULL

C语言 二级指针内存模型③

//二级指针内存模型③ #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <string.h> //内存模型详解 //一维数组类型是 typedef int Myarr[5]; Myarr a;(其中Myarr是一维数组类型) //Myarr *p;p是一维数组的指针 //是一维数组的指针的类型是 typedef int(*PArrType)[5]; PArrT

c语言二级指针内存模型

第一种: 指针数组作为输入参数 char *myArray[] = {"aaaaaa", "ccccc", "bbbbbb", "111111"};//指针数组,数组中的每个元素都是指针,int num = 4; void printMyArray11(char **myArray, int num) { int i = 0; for (i=0; i<num; i++) { //printf("%s \n&qu

C二级指针内存模型一

#include <stdio.h> #include <stdlib.h> #include <string.h> /* 二级指针的第一种内存模型 */ //打印字符串数组 int printArray(char **arrayStr,int num) {     int i = 0;     for (i=0; i<num; i++)     {         printf("%s \n",arrayStr[i]);     }     

C二级指针内存模型二

#include <stdio.h> #include <stdlib.h> #include <string.h> /* 二级指针的第二种内存模型 */ //打印字符串数组 int printArray(char arrayStr[10][30],int num) {     int i = 0;     for (i=0; i<num; i++)     {         printf("%s \n",arrayStr[i]);     

C语言 二级指针内存模型

//二级指针第一种内存模型 #include<stdio.h> #include<stdlib.h> //说明:①:类似于int a[5]={0},数组名a是一维数组a中首元素的指针:(我自认为此假设可应用于多维数组与指针) //②二级指针的主要功能是修改一级指针的值 //打印一维数组 int PrintArr(char **pin,int num){ int ERRO_MSG = 0; if (pin==NULL) { ERRO_MSG = 1; printf("pin

二级指针内存模型(一)

二级指针做输入 #include<stdio.h> #include<string.h> #include<stdlib.h> int getMem(char **myp1,int *mylen1,char **myp2,int *mylen2) { char *tmp1 = NULL; char *tmp2 = NULL; tmp1 = (char *)malloc(100); if(tmp1 == NULL) { return -1; } strcpy(tmp1,&

二级指针内存模型(二)

二级指针做输入,此时交换的是指针指向的内存 #include<stdio.h> #include<stdlib.h> #include<string.h> void printMyarray(char myArray[10][30],int num) { int i; for(i = 0; i < num; i++) { //printf("%s \n",myArray[i]); printf("%s \n",*(myArr