C语言下一个双指针的事例

今天需要用到一个双指针,不太熟悉其使用方法,网上没找到合适的事例,于是自己尝试写一个。只要理解了指针的含义,还是不难。

代码全部如下:

 

#include "stdafx.h"
#include <stdlib.h>
#include <memory.h>
#include <string.h>

 

//定义结构体

typedef struct tagUSERCLASSTYPE
{
 char szName[32];
 char szID[18];
 int  szAge;
} User_t, *UserPtr_t;

 

int main(int argc, char* argv[])
{
 User_t **pp = (User_t**)malloc(sizeof(User_t*) * 2);
 User_t **tmp;

 tmp = pp;

 

 for (int i=0; i<2; i++)
 {
  (*tmp) = (User_t*)malloc(sizeof(User_t));
  tmp++;
 }

 

 tmp = pp;
 strcpy((*tmp)->szName, "aaa");
 strcpy((*tmp)->szID, "001");
 (*tmp)->szAge = 10;

 

 tmp++;
 strcpy((*tmp)->szName, "bbb");
 strcpy((*tmp)->szID, "002");
 (*tmp)->szAge = 20;

 

 tmp = pp;
 for (i=0; i<2; i++)
 {
  printf("name: %s, id: %s, age: %d/r/n", (*tmp)->szName, (*tmp)->szID, (*tmp)->szAge);
  tmp++;
 }

 

//释放,注意释放次序

//先释放结构体指针所指向的内存

 tmp = pp;
 for (i=0; i<2; i++)
 {
  free(*tmp);

  tmp++;
 }

 

//再释放结构体指针数组的内存

for (i=0; i<2; i++)
 {
  free (*tmp);
  tmp++;
 }

 pp = NULL;
 tmp = NULL;

 return 0;
}

创建和初始化一个二叉树实例通常涉及定义一个结构体来表示二叉树的节点,并设置节点值以及指向左孩子和右孩子的指针。下面是一个C语言的例子,展示如何创建一个简单的二叉树: ```c #include <stdio.h> #include <stdlib.h> // 定义二叉树节点结构体 typedef struct TreeNode { int data; // 节点数据 struct TreeNode* left; // 左孩子指针 struct TreeNode* right; // 右孩子指针 } Node; // 初始化一个新的二叉树节点 Node* createNewNode(int data) { Node* newNode = (Node*)malloc(sizeof(Node)); newNode->data = data; newNode->left = NULL; newNode->right = NULL; return newNode; } // 示例:创建一个特定结构的二叉树 void createExampleTree(Node** root) { *root = createNewNode(10); // 根节点 (*root)->left = createNewNode(5); // 根节点的左子树 (*root)->left->right = createNewNode(15); // 左子树的右子树 (*root)->right = createNewNode(20); // 根节点的右子树 } // 打印二叉树(这里仅做演示,实际应用中需实现) void printInorder(Node* node) { if (node != NULL) { printInorder(node->left); printf("%d ", node->data); printInorder(node->right); } } int main() { Node* root = NULL; createExampleTree(&root); printf("Binary Tree Example:\n"); printInorder(root); // 输出: 5 10 15 20 // 清理内存 if (root) { free(root->left); free(root->right); free(root); } return 0; } ``` 这个例子中,`createExampleTree`函数创建了一个根节点为10,左子树有5和15,右子树有20的二叉树。然后通过`printInorder`函数展示了按照从左到右、再到根、再到右的顺序打印出来的节点值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值