第 1 章 绪论 (三元组)

news2024/11/24 4:48:42

1.  示例代码:

1)status.h

/* DataStructure 预定义常量和类型头文件 */

#ifndef STATUS_H
#define STATUS_H

/* 函数结果状态码 */
#define TRUE 					1			/* 返回值为真 */
#define FALSE 					0			/* 返回值为假 */
#define RET_OK 					0			/* 返回值正确 */
#define INFEASIABLE    		   	2			/* 返回值未知 */
#define ERR_MEMORY     		   	3			/* 访问内存错 */
#define ERR_NULL_PTR   			4			/* 空指针错误 */
#define ERR_MEMORY_ALLOCATE		5			/* 内存分配错 */
#define ERR_NULL_STACK			6			/* 栈元素为空 */
#define ERR_PARA				7			/* 函数参数错 */
#define ERR_OPEN_FILE			8			/* 打开文件错 */
typedef int Status;							/* Status 是函数的类型,其值是函数结果状态代码,如 OK 等 */
typedef int Bollean;						/* Boolean 是布尔类型,其值是 TRUE 或 FALSE */

#endif // !STATUS_H

2) triplet.h

/* 抽象数据类型 Triplet 和 ElemType 的基本操作头文件 */

#ifndef TRIPLET_H
#define TRIPLET_H

#include "status.h"
#define SIZE 3

typedef int ElemType;				/* 定义抽象数据类型 ElemType 在本程序中为整型 */
typedef ElemType* Triplet;			/* 由 InitTriplet 分配三个元素存储空间 */

/* 操作结果:构造三元组 T,依次置 T 的三个元素的初值为 v1, v2 和 v3 */
Status InitTriplet(Triplet* T, ElemType v1, ElemType v2, ElemType v3);

/* 操作结果:三元组 T 被销毁 */
void DestroyTriplet(Triplet* T);

/* 初始条件:三元组 T 已存在,1 ≤ i ≤ 3。操作结果:用 e 返回 T 的第 i 元的值 */
Status Get(Triplet T, int i, ElemType* e);

/* 初始条件:三元组 T 已存在,1 ≤ i ≤3。操作结果:改变 T 的第 i 元的值为 e */
Status Put(Triplet T, int i, ElemType e);

/* 初始条件:三元组 T 已存在。操作结果:如果 T 的三个元素按升序排列,返回 1,否则返回 0 */
Bollean IsAscending(Triplet T);

/* 初始条件:三元组 T 已存在。操作结果:如果 T 的三个元素按降序排列,返回 1,否则返回 0 */
Bollean IsDescending(Triplet T);

/* 初始条件:三元组 T 已存在。操作结果:用 e 返回 T 的三个元素中的最大值 */
void Max(Triplet T, ElemType* e);

/* 初始条件:三元组 T 已存在。操作结果:用 e 返回 T 的三个元素中的最小值 */
void Min(Triplet T, ElemType* e);

#endif // !TRIPLET_H

3) triplet.c

/* 抽象数据类型 Triplet 和 ElemType 的基本操作实现 */
#include "triplet.h"
#include <stdlib.h>			/* 提供 malloc() 函数原型*/
#include <stdio.h>

/* 操作结果:构造三元组 T,依次置 T 的三个元素的初值为 v1, v2 和 v3 */
Status InitTriplet(Triplet* T, ElemType v1, ElemType v2, ElemType v3)
{
	*T = (ElemType*)malloc(sizeof(ElemType) * SIZE);
	if (!(*T)) {
		printf("FuncName: %-15s Line: %-5d ErrorCode: %-3d\n", __func__, __LINE__, ERR_MEMORY_ALLOCATE);
		return ERR_MEMORY_ALLOCATE;
	}

	(*T)[0] = v1;
	(*T)[1] = v2;
	(*T)[2] = v3;

	return RET_OK;
}

/* 操作结果:三元组 T 被销毁 */
void DestroyTriplet(Triplet* T)
{
	free(*T);
	*T = NULL;
}

/* 初始条件:三元组 T 已存在,1 ≤ i ≤ 3。操作结果:用 e 返回 T 的第 i 元的值 */
Status Get(Triplet T, int i, ElemType* e)
{
	if (i < 1 || i > 3) {
		printf("FuncName: %-15s Line: %-5d ErrorCode: %-3d\n", __func__, __LINE__, ERR_PARA);
		return ERR_PARA;
	}

	*e = T[i - 1];

	return RET_OK;
}

/* 初始条件:三元组 T 已存在,1 ≤ i ≤3。操作结果:改变 T 的第 i 元的值为 e */
Status Put(Triplet T, int i, ElemType e)
{
	if (i < 1 || i > 3) {
		printf("FuncName: %-15s Line: %-5d ErrorCode: %-3d\n", __func__, __LINE__, ERR_PARA);
		return ERR_PARA;
	}

	T[i - 1] = e;

	return RET_OK;
}

/* 初始条件:三元组 T 已存在。操作结果:如果 T 的三个元素按升序排列,返回 1,否则返回 0 */
Bollean IsAscending(Triplet T)
{
	return (T[0] <= T[1] && T[1] <= T[2]);
}

/* 初始条件:三元组 T 已存在。操作结果:如果 T 的三个元素按降序排列,返回 1,否则返回 0 */
Bollean IsDescending(Triplet T)
{
	return (T[0] >= T[1] && T[1] >= T[2]);
}

/* 初始条件:三元组 T 已存在。操作结果:用 e 返回 T 的三个元素中的最大值 */
void Max(Triplet T, ElemType* e)
{
	*e = (T[0] >= T[1]) ? ((T[0] >= T[2]) ? T[0] : T[2]) : ((T[1] >= T[2]) ? T[1] : T[2]);
}

/* 初始条件:三元组 T 已存在。操作结果:用 e 返回 T 的三个元素中的最小值 */
void Min(Triplet T, ElemType* e)
{
	*e = (T[0] <= T[1]) ? ((T[0] < T[2]) ? T[0] : T[2]) : ((T[1] <= T[2]) ? T[1] : T[2]);
}

4) main.c

#include <stdio.h>
#include "status.h"
#include "triplet.h"

int main(void)
{
	Triplet T;
	/* 初始化三元组 */
	Status ret = InitTriplet(&T, 5, 7, 9);
	printf("初始化三元组%s, T[0] = %d, T[1] = %d, T[2] = %d\n\n", ret == RET_OK ? "成功" : "失败", T[0], T[1], T[2]);

	/* 获取三元组第 i 个值 */
	ElemType e;
	int i = 2;
	ret = Get(T, i, &e);
	if (ret != RET_OK) {
		printf("FuncName: %-15s Line: %-5d ErrorCode: %-3d\n", __func__, __LINE__, ret);
		return ret;
	}

	printf("获取成功,T 的第 %d 个值为:%d\n\n", i, e);

	/* 改变三元组第 i 个值 */
	e = 6;
	ret = Put(T, i, e);
	if (ret != RET_OK) {
		printf("FuncName: %-15s Line: %-5d ErrorCode: %-3d\n", __func__, __LINE__, ret);
		return ret;
	}

	printf("改变三元组成功,T 的第 %d 个值为:%d\n\n", i, T[i - 1]);

	/* 判断三元组是否升序 */
	ret = IsAscending(T);
	printf("该三元组为%s\n\n", ret == TRUE ? "升序" : "非升序");

	/* 判断三元组是否降序 */
	ret = IsDescending(T);
	printf("该三元组为%s\n\n", ret == TRUE ? "降序" : "非降序");

	/* 获取三元组中最大值 */
	Max(T, &e);
	printf("三元组中最大值为:%d\n\n", e);

	/* 获取三元组中最小值 */
	Min(T, &e);
	printf("三元组中最小值为:%d\n\n", e);

	/* 销毁三元组 */
	DestroyTriplet(&T);

	return 0;
}

2.  输出示例:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/942094.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电脑不安装软件,怎么将手机文件传输到电脑?

很多人都知道&#xff0c;AirDroid有网页版&#xff08;web.airdroid.com&#xff09;。 想要文件传输&#xff0c;却不想在电脑安装软件时&#xff0c;AirDroid的网页版其实也可以传输文件。 然而&#xff0c;要将文件从手机传输文件到网页端所在的电脑时&#xff0c;如果按…

Vue05_关于插槽和指令封装的运用

Vue_05 文章目录 Vue_05Vue 插槽01-插槽-默认插槽默认插槽-基本语法 02-插槽-后备内容&#xff08;默认值&#xff09;默认值设置方法 03-插槽-具名插槽具名插槽-语法 04-插槽-作用域插槽默认插槽-语法代码示例 Vue自定义指令- v-loading封装01-自定义指令自定义指令的两种注册…

【算法专题突破】双指针 - 盛最多水的容器(4)

目录 1. 题目解析 2. 算法原理 3. 代码编写 写在最后&#xff1a; 1. 题目解析 题目链接&#xff1a;11. 盛最多水的容器 - 力扣&#xff08;Leetcode&#xff09; 这道题目也不难理解&#xff0c; 两边的柱子的盛水量是根据短的那边的柱子决定的&#xff0c; 而盛水量…

如何清空小程序会员卡的电子票

​电子票不仅方便了用户的购票和消费&#xff0c;还提升了用户的购物体验和忠诚度。然而&#xff0c;在一些特殊情况下&#xff0c;可能需要手动清空会员的电子票。那么&#xff0c;下面我们就来探讨一下在小程序中如何手动清空会员的电子票。 1. 找到指定的会员卡。在管理员后…

15.CSS发光按钮的悬停特效

效果 源码 <!DOCTYPE html> <html> <head><title>CSS Modern Button</title><link rel="stylesheet" type="text/css" href="style.css"> </head> <body><a href="#" style=&quo…

Flink CDC学习笔记

第一章 CDC简介 1.1 什么是CDC ​ CDC (Change Data Capture 变更数据获取&#xff09;的简称。核心思想就是&#xff0c;检测并获取数据库的变动&#xff08;增删查改&#xff09;&#xff0c;将这些变更按发生的顺序记录下来&#xff0c;写入到消息中间件以供其它服务进行订…

公网远程访问局域网SQL Server数据库

文章目录 1.前言2.本地安装和设置SQL Server2.1 SQL Server下载2.2 SQL Server本地连接测试2.3 Cpolar内网穿透的下载和安装2.3 Cpolar内网穿透的注册 3.本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4.公网访问测试5.结语 1.前言 数据库的重要性相信大家都有所了解&…

Deep Learning With Pytorch - 数据预处理,以导入LUNA16数据集为例

文章目录 数据集简介什么是CT扫描&#xff1f;导入大型数据集并不是一份轻松的工作 在Jupyter Notebook中导入LUNA16数据集导入可能用到的第三方库&#xff1a;LUNA16存放路径&#xff1a;用 pandas 读取 candidates.csv&#xff1b;读取 annotations.csv导入subset0和subset1的…

[FPGA IP系列] BRAM IP参数配置与使用示例

FPGA开发中使用频率非常高的两个IP就是FIFO和BRAM&#xff0c;上一篇文章中已经详细介绍了Vivado FIFO IP&#xff0c;今天我们来聊一聊BRAM IP。 本文将详细介绍Vivado中BRAM IP的配置方式和使用技巧。 一、BRAM IP核的配置 1、打开BRAM IP核 在Vivado的IP Catalog中找到B…

ubuntu上安装nginx

这篇文章主要介绍怎么在ubuntu上安装nginx服务器&#xff0c;并配置简单的反向代理功能。 第一步&#xff1a;准备好一台ubuntu操作系统的虚拟机 注意&#xff1a;如果你还没有安装好ubuntu&#xff0c;个人推荐阅读以下文章完成unbutu安装&#xff0c;vm的版本不用刻意安装文…

Python ArcPy将多个文件夹内大量遥感影像批量四等分裁剪或切割为N×M个部分

本文介绍基于Python中的ArcPy模块&#xff0c;基于一个大文件夹&#xff0c;遍历其中每一个子文件夹中所有的遥感影像栅格文件&#xff0c;并将原本的每一景遥感影像文件四等分切割&#xff0c;或裁剪为其他指定个数的小块的方法。 首先明确一下我们的需求。现有一个大文件夹&a…

数据结构之单链表java实现

基本概念 链表是一种物理存储结构上非连续、非顺序的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中指针链接次序实现的。和数组相比较&#xff0c;链表不需要指定大小&#xff0c;也不需要连续的地址。 单链表的基本设计思维是&#xff0c;利用结构体的设置&#xff0c…

平衡二叉树(AVL树)C++

目录 AVL树的概念 AVL树的节点结构 AVL树的插入 更新平衡节点 代码实现 AVL树的旋转 左单旋 右单旋 左右双旋 右左双旋 AVL树的删除 AVL树的查找 AVL树的高度 AVL树的判定 AVL树的遍历 AVL树的概念 二叉排序&#xff08;搜索&#xff09;树&#xff0c;虽然可以…

葡萄叶病害识别(图像连续识别和视频识别,Python代码,pyTorch框架)

葡萄叶病害识别&#xff08;图像连续识别和视频识别&#xff0c;Python代码&#xff0c;pyTorch框架&#xff09;_哔哩哔哩_bilibili 葡萄数据集 第一个文件夹为 Grape Black Measles&#xff08;葡萄黑麻疹&#xff09;病害&#xff08;3783张&#xff09; Grape Black rot葡…

108页石油石化5G智慧炼化厂整体方案PPT

导读&#xff1a;原文《108页石油石化5G智慧炼化厂整体方案PPT》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。以下是部分内容&#xff0c; P P T 喜欢文章&#xf…

【BUG事务内消息发送】事务内消息发送,事务还未结束,消息发送已被消费,查无数据怎么解决?

问题描述 在一个事务内完成插入操作&#xff0c;通过MQ异步通知其他微服务进行事件处理。 由于是在事务内发送&#xff0c;其他服务消费消息&#xff0c;查询数据时还不存在如何解决呢&#xff1f; 解决方案 通过spring-tx包的TransactionSynchronizationManager事务管理器解…

管理与领导-58]:IT基层管理者 - 扩展技能 - 1 - 时间管理 -5- 持续改进— 时间管理的好习惯

前言&#xff1a; 对于大多数管理者而言&#xff0c;提高效能并不能一步到位&#xff0c;需要不断的实践、总结、持续的改进和优化&#xff0c;最终达到较高的效能&#xff0c;持续学习、持续改进是管理者一项终身精进的能力&#xff01;&#xff01;&#xff01;养成时刻进行…

程序员赚钱的六种方式:技术实力和市场分析能力是关键

随着互联网的普及和发展&#xff0c;越来越多的人开始在网上寻找商机&#xff0c;其中程序员作为一个高技能的群体&#xff0c;可以利用自身的编程技术在网上获得收益。以下是一些程序员可以利用自己的编程技术在网上赚钱的途径&#xff1a; 开发软件&#xff1a;程序员可以利…

Spring Boot(Vue3+ElementPlus+Axios+MyBatisPlus+Spring Boot 前后端分离)【五】

&#x1f600;前言 本篇博文是关于Spring Boot(Vue3ElementPlusAxiosMyBatisPlusSpring Boot 前后端分离)【五】&#xff0c;希望你能够喜欢 &#x1f3e0;个人主页&#xff1a;晨犀主页 &#x1f9d1;个人简介&#xff1a;大家好&#xff0c;我是晨犀&#xff0c;希望我的文章…

本地组策略编辑器找不到怎么解决?| 解决windows home 版本隐藏本地组策略编辑器的问题 | 简单的介绍本地组策略编辑器

一般的 Windows 非家庭系统中&#xff0c;本地组策略编辑器不会被隐藏&#xff0c;但在某些特定情况下&#xff0c;可能会受到限制或不可用。如果你无法访问本地组策略编辑器&#xff0c;并且认为应该可以访问&#xff0c;请确保你拥有管理员权限&#xff0c;并检查是否有任何系…