typedef 使用大全2(结构体)

本文详细介绍了C语言中结构体的定义与使用方法,包括基本结构体、多级指针指向结构体以及结构体内嵌结构体的操作方式。通过具体实例展示了不同类型的结构体变量及其之间的相互引用。

续 数组

#define S(s) printf("%s/n", #s); s

 

typedef struct _TS1{

    int x, y;

TS1, *PTS1, ***PPPTS1;  // TS1是结构体的名称,PTS1是结构体指针的名称

// 也就是将结构体struct _TS1 命名为TS1,

// 将struct _TS1 * 命名为 PTS1

// 将struct _TS1 *** 命名为 PPPTS1

 

typedef struct { // struct后面的结构体说明也可以去掉

    int x, y;

TS2, *PTS2;

 

typedef PTS1 *PPTS1// 定义PPTS1是指向PTS1的指针

 

typedef struct _TTS1{

    typedef struct ITTS1 {

        int x, y;

    } iner;

    iner i;

    int x, y;

} TTS1;

 

//结构体内部的结构体也一样可以定义

typedef TTS1::ITTS1 ITS1;

 

void test_struct()

{

    // 基本结构体重定义的使用

    TS1 ts1 = {100, 200};

    PTS1 pts1 = &ts1; // 完全等价于TS1* pts1 = &ts1;

    PPTS1 ppts1 = &pts1; // 完全等价于TS1** ppts1 = &pts1;

    PPPTS1 pppts1 = &ppts1; // 完全等价于 TS1*** pppts1 = &ppts1;

 

    TS2 ts2 = {99, 88};

    PTS2 pts2 = &ts2;   // 完全等价于 TS2* pts2 = &ts2;

 

    TTS1 itts1 = {{110, 220}, 10, 20};

    Its1* rits1 = &itts1.i;

    ITS1&its1 = rits1; // 等价于 TTS1::ITTS1 *its1 = &(itts1.i);

 

    printf("ts1/t = (%d, %d)/n*pts1/t = (%d, %d)/n"

           "**ppts1/t = (%d, %d)/n***pppts1= (%d, %d)/n/n",

            ts1.x, ts1.y, pts1->x, pts1->y,

            (**ppts1).x, (**ppts1).y, (***pppts1).x, (***pppts1).y);

    printf("ts2/t = (%d, %d)/n*pts2/t = (%d, %d)/n/n",

        ts2.x, ts2.y, pts2->x, pts2->y);

    printf("itts1/t = [(%d, %d), %d, %d]/n*its1/t =  (%d, %d)/n/n",

        itts1.i.x, itts1.i.y, itts1.x, itts1.y, its1->x, its1->y);

 

    S(pts1->x = 119);

    S(pts2->y = 911);

    S(its1->x = 999);

 

    printf("ts1/t = (%d, %d)/n*pts1/t = (%d, %d)/n"

           "**ppts1/t = (%d, %d)/n***pppts1= (%d, %d)/n/n",

            ts1.x, ts1.y, pts1->x, pts1->y,

            (**ppts1).x, (**ppts1).y, (***pppts1).x, (***pppts1).y);

    printf("ts2/t = (%d, %d)/n*pts2/t = (%d, %d)/n/n",

        ts2.x, ts2.y, pts2->x, pts2->y);

    printf("itts1/t = [(%d, %d), %d, %d]/n*its1/t =  (%d, %d)/n/n",

        itts1.i.x, itts1.i.y, itts1.x, itts1.y, its1->x, its1->y);

 

    S((*ppts1)->y = -9999);

    printf("ts1/t = (%d, %d)/n**ppts1/t = (%d, %d)/n/n",

        ts1.x, ts1.y, (*ppts1)->x, (*ppts1)->y);

 

    S((**pppts1)->x = -12345);

    S((***pppts1).y = -67890);

    printf("ts1/t = (%d, %d)/n*pts1/t = (%d, %d)/n"

           "**ppts1/t = (%d, %d)/n***pppts1= (%d, %d)/n/n",

            ts1.x, ts1.y, pts1->x, pts1->y,

            (**ppts1).x, (**ppts1).y, (***pppts1).x, (***pppts1).y);

}


http://blog.youkuaiyun.com/eion/article/details/14547

【最优潮流】直流最优潮流(OPF)课设(Matlab代码实现)内容概要:本文档主要围绕“直流最优潮流(OPF)课设”的Matlab代码实现展开,属于电力系统优化领域的教学与科研实践内容。文档介绍了通过Matlab进行电力系统最优潮流计算的基本原理与编程实现方法,重点聚焦于直流最优潮流模型的构建与求解过程,适用于课程设计或科研入门实践。文中提及使用YALMIP等优化工具包进行建模,并提供了相关资源下载链接,便于读者复现与学习。此外,文档还列举了大量与电力系统、智能优化算法、机器学习、路径规划等相关的Matlab仿真案例,体现出其服务于科研仿真辅导的综合性平台性质。; 适合人群:电气工程、自动化、电力系统及相关专业的本科生、研究生,以及从事电力系统优化、智能算法应用研究的科研人员。; 使用场景及目标:①掌握直流最优潮流的基本原理与Matlab实现方法;②完成课程设计或科研项目中的电力系统优化任务;③借助提供的丰富案例资源,拓展在智能优化、状态估计、微电网调度等方向的研究思路与技术手段。; 阅读建议:建议读者结合文档中提供的网盘资源,下载完整代码与工具包,边学习理论边动手实践。重点关注YALMIP工具的使用方法,并通过复现文中提到的多个案例,加深对电力系统优化问题建模与求解的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值