2.4、求顺序表中的最大值和次大值

2.4、求顺序表中的最大值和次大值

2.5、元素 x 插入递增有序的顺序表

 2.6、合并两个递增顺序表 / 单链表

2.7、求俩递增单链表的交集单链表

Dev-C++ 6.6 安装程序

Visual Studio 2019 安装程序

/************************************************************
* Windows 10下,Dev-C++ 6.6、Visual Studio 2019 中测试通过	*
*															*
* @file		习题2.4.c										*
*															*
* @brief	习题2.4											*
*			编写算法输出已知顺序表 A 中						*
*			数据元素的最大值和次大值。用					*
*			非形式算法描述,并编写C语言程序。				*
*															*
* @author	优快云@洛必不达法则								*
*															*
* @date		2021-10-17										*
*************************************************************/

#define _CRT_SECURE_NO_WARNINGS		// VS2019中 scanf 被认为是不安全的,需要加上该宏才能使用
#include <stdio.h>
#include <stdlib.h>

/**
* @brief	定义顺序表结构体
*/
typedef struct
{
	int* data;		// 存储数据元素的一段内存
	int last;		// 最后一个元素的下标
	int maxsize;	// 最大容量
}SeqList;

/**
* @brief	初始化顺序表
* @param maxsize	顺序表的容量
* @return	初始化成功的顺序表地址
*/
SeqList* InitSeqList(int maxsize)
{
	SeqList* pList = (SeqList*)malloc(sizeof(SeqList));
	if (!pList)
	{
		printf("内存申请失败!\n");
		return NULL;
	}
	pList->data = (int*)malloc(sizeof(int) * maxsize);
	if (!pList->data)
	{
		printf("内存申请失败!\n");
		return NULL;
	}
	pList->maxsize = maxsize;
	pList->last = -1;
	return pList;
}

/**
* @brief	创建顺序表
* @return	创建的顺序表的地址
*/
SeqList* CreateSeqList()
{
	int maxsize = 0;
	int data = 0;
	printf("设置顺序表的容量:");
	scanf("%d", &maxsize);
	SeqList* pList = InitSeqList(maxsize);
	printf("输入顺序表的数据(输入任意字母字符结束):\n");
	while (pList->last < pList->maxsize - 1)
	{
		if (!scanf("%d", &data))
			break;
		pList->data[++pList->last] = data;
	}
	return pList;
}

/**
* @brief	遍历打印顺序表表数据
* @param pList	需要遍历的顺序表
*/
void PrintSeqList(SeqList* pList)
{
	for (int i = 0; i <= pList->last; i++)
	{
		printf("%d  ", pList->data[i]);
	}
	printf("\n");
}

/**
* @brief	获取顺序表中的最大值和次大值,以数组形式返回
* @param pList	待求顺序表
* @return	一个长度为2的整型数组,下标0为最大值,下标1为次大值
*/
int* GetSeqListMaxAndSec(SeqList* pList)
{
	// int max[2]; 在 Dev-C++ 6.6 中测试不通过
	int* max = (int*)malloc(sizeof(int) * 2);

	// 空表,最大值和次大值都取0
	if (pList->last == -1)
	{
		max[0] = 0;
		max[1] = 0;
		return max;
	}
	// 顺序表不为空
	else
	{
		// 最大值和次大值初始值为data[0]
		max[0] = pList->data[0];
		max[1] = pList->data[0];
		// 从data[1]开始比较
		for (int i = 1; i <= pList->last; i++)
		{
			if (pList->data[i] > max[0])
			{
				max[1] = max[0];
				max[0] = pList->data[i];
			}
			else if (pList->data[i] < max[0] && (pList->data[i] > max[1] || max[0] == max[1]))
			{
				max[1] = pList->data[i];
			}
		}
		return max;
	}
}

int main()
{
	printf("\t********* 习题2.4 *********\n");
	SeqList* A = CreateSeqList();

	printf("打印顺序表表:\n");
	PrintSeqList(A);

	int* max2 = GetSeqListMaxAndSec(A);
	printf("\n最大值为:%d,次大值为:%d\n", max2[0], max2[1]);

	return 0;
}

### 安装mmcv版本0.9与Python 3.6环境 要在Python 3.6环境中安装特定版本的 `mmcv`(即版本0.9),可以按照以下方法操作: #### 方法一:通过pip安装指定版本 如果目标机器已配置好支持Python 3.6的pip工具,则可以通过命令行直接安装所需的 `mmcv` 版本。 运行以下命令来安装 `mmcv==0.9`: ```bash pip install mmcv==0.9 ``` 此命令会自动下载并安装对应版本的 `mmcv` 库到当前激活的Python虚拟环境中[^1]。 #### 方法二:验证依赖项兼容性 由于某些库可能对不同版本的Python存在兼容性问题,在执行上述命令之前,建议先确认所使用的Python解释器是否满足最低要求。对于Python 3.6的支持情况,通常需要查阅官方文档或源码仓库中的说明文件以获取更详细的指导信息[^2]。 另外需要注意的是,部分深度学习框架及其扩展模块可能会绑定特定CUDA驱动程序或者cuDNN SDK版本号,请确保本地开发平台已经正确设置了这些必要的硬件加速组件[^3]。 #### 方法三:手动编译安装(可选) 当预构建包无法适用于特殊场景时,可以选择从源代码开始自行构建适合自己的软件副本。具体流程如下所示: 1. **克隆项目存储库** 使用Git客户端拉取最新版源码至工作目录下: ```bash git clone https://github.com/open-mmlab/mmcv.git cd mmcv ``` 2. **切换分支/标签** 找到对应的release tag名称, 并检出该历史提交记录作为基础进行后续定制化修改. ```bash git checkout tags/v0.9 -b v0.9-branch ``` 3. **准备环境变量** 设置一些全局参数以便于交叉编译过程顺利开展. 4. **启动makefile脚本** 根据提示逐步完成整个组装环节直至最终产物生成完毕为止. 以上便是关于如何利用Python 3.6成功部署MMDetection核心组成部分之一——MMCV Version 0.9 的解决方案概述。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值