双向链表

#include <stdio.h>
#include <assert.h>

typedef struct _DOUBLE_LINK_NODE
{
	int data;
	struct _DOUBLE_LINK_NODE* prev;
	struct _DOUBLE_LINK_NODE* next;
}DOUBLE_LINK_NODE;


/*
创建一个节点,使节点的prev=NULL next=NULL	value=xxx
返回值:创建的节点
*/
DOUBLE_LINK_NODE* create_double_link_node(int value)
{
	DOUBLE_LINK_NODE* pDLinkNode = NULL;
	pDLinkNode = (DOUBLE_LINK_NODE*)malloc(sizeof(DOUBLE_LINK_NODE));
	assert(NULL != pDLinkNode);

	memset(pDLinkNode, 0, sizeof(DOUBLE_LINK_NODE));
	pDLinkNode->data = value;
	return pDLinkNode;
}


/*
*  *pDLinkNode即为双向链表的头结点指针
*/
void delete_all_double_link_node(DOUBLE_LINK_NODE** pDLinkNode)
{
	DOUBLE_LINK_NODE* pNode;
	if(NULL == *pDLinkNode)
		return ;
	
	//先获得当前节点
	pNode = *pDLinkNode;
	//再让pDLinkNode指向当前的下个节点
	*pDLinkNode = pNode->next;
	//释放之前获得的节点
	free(pNode);
	
	//继续处理下个节点
	delete_all_double_link_node(pDLinkNode);
}


/*
* pDLinkNode即为双向链表的头结点指针
*/
DOUBLE_LINK_NODE* find_data_in_double_link(const DOUBLE_LINK_NODE* pDLinkNode, int data)
{
	DOUBLE_LINK_NODE* pNode = NULL;
	if(NULL == pDLinkNode)
		return NULL;

	pNode = (DOUBLE_LINK_NODE*)pDLinkNode;
	while(NULL != pNode){
		if(data == pNode->data)
			return pNode;
		pNode = pNode ->next;
	}
	
	return NULL;
}


int insert_data_into_double_link(DOUBLE_LINK_NODE** ppDLinkNode, int data)
{
	DOUBLE_LINK_NODE* pNode;
	DOUBLE_LINK_NODE* pIndex;

	if(NULL == ppDLinkNode)
		return 0;

	//当前链表没有一个节点时候
	if(NULL == *ppDLinkNode){
		pNode = create_double_link_node(data);
	    assert(NULL != pNode);
		*ppDLinkNode = pNode;
		(*ppDLinkNode)->prev = (*ppDLinkNode)->next = NULL;
		return 1;
	}

	if(NULL != find_data_in_double_link(*ppDLinkNode, data))
		return 0;

	//需要插入的节点pNode
	pNode = create_double_link_node(data);
	assert(NULL != pNode);

	//先得到最后个节点, pIndex指向最后个节点
	pIndex = *ppDLinkNode;
	while(NULL != pIndex->next)
		pIndex = pIndex->next;
		
	//将需要插入的节点插入链表末尾
	pNode->prev = pIndex;
	pNode->next = pIndex->next;
	pIndex->next = pNode;
	return 1;
}


int delete_data_from_double_link(DOUBLE_LINK_NODE** ppDLinkNode, int data)
{
	DOUBLE_LINK_NODE* pNode;
	if(NULL == ppDLinkNode || NULL == *ppDLinkNode)
		return 0;

	pNode = find_data_in_double_link(*ppDLinkNode, data);
	if(NULL == pNode)
		return 0;

	//要删除的pNode是头结点
	if(pNode == *ppDLinkNode)
	{
		if(NULL == (*ppDLinkNode)->next){
			*ppDLinkNode = NULL;
		}else{
			*ppDLinkNode = pNode->next;
			(*ppDLinkNode)->prev = NULL;
		}

	}else
	{
		if(pNode->next)
		    pNode->next->prev = pNode->prev;
	    pNode->prev->next = pNode->next;
	}

	free(pNode);
	return 1;
}

int count_number_in_double_link(const DOUBLE_LINK_NODE* pDLinkNode)
{
	int count = 0;
	DOUBLE_LINK_NODE* pNode = (DOUBLE_LINK_NODE*)pDLinkNode;

	while(NULL != pNode){
		count ++;
		pNode = pNode->next;
	}
	return count;
}

void print_double_link_node(const DOUBLE_LINK_NODE* pDLinkNode)
{
	DOUBLE_LINK_NODE* pNode = (DOUBLE_LINK_NODE*)pDLinkNode;

	while(NULL != pNode){
		printf("%d\n", pNode->data);
		pNode = pNode ->next;
	}
}

int main()
{
	DOUBLE_LINK_NODE *dlist =  create_double_link_node(5);
	if(insert_data_into_double_link(&dlist, 4))printf("insert ok\n");
	if(insert_data_into_double_link(&dlist, 3))printf("insert ok\n");
	if(insert_data_into_double_link(&dlist, 2))printf("insert ok\n");
	if(insert_data_into_double_link(&dlist, 1))printf("insert ok\n");
	if(insert_data_into_double_link(&dlist, 5))printf("insert error , has existed\n");
		
	printf("---------------------------------------------\n");
	
	DOUBLE_LINK_NODE *p =  find_data_in_double_link(dlist, 3);
	if(p!= NULL)
		printf("find p->data=%d\n", p->data);
	else
		printf("not find\n");
	
	p = NULL;
	p =  find_data_in_double_link(dlist, 10);
	if(p!=NULL)
		printf("find p->data=%d\n", p->data);
	else
		printf("not find\n");
		
	printf("---------------------------------------------\n");
	
	if(delete_data_from_double_link(&dlist, 1))
		printf("delete ok\n");
	
	printf("---------------------------------------------\n");
	print_double_link_node(dlist);
	int len = count_number_in_double_link(dlist);
	printf("double link cnt=%d\n", len);
	
	printf("---------------------------------------------\n");
	delete_all_double_link_node(&dlist);
	len = count_number_in_double_link(dlist);
	printf("double link cnt=%d\n", len);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像识别技术在病虫害检测中的应用是一个快速发展的领域,它结合了计算机视觉和机器学习算法来自动识别和分类植物上的病虫害。以下是这一技术的一些关键步骤和组成部分: 1. **数据收集**:首先需要收集大量的植物图像数据,这些数据包括健康植物的图像以及受不同病虫害影响的植物图像。 2. **图像预处理**:对收集到的图像进行处理,以提高后续分析的准确性。这可能包括调整亮度、对比度、去噪、裁剪、缩放等。 3. **特征提取**:从图像中提取有助于识别病虫害的特征。这些特征可能包括颜色、纹理、形状、边缘等。 4. **模型训练**:使用机器学习算法(如支持向量机、随机森林、卷积神经网络等)来训练模型。训练过程中,算法会学习如何根据提取的特征来识别不同的病虫害。 5. **模型验证和测试**:在独立的测试集上验证模型的性能,以确保其准确性和泛化能力。 6. **部署和应用**:将训练好的模型部署到实际的病虫害检测系统中,可以是移动应用、网页服务或集成到智能农业设备中。 7. **实时监测**:在实际应用中,系统可以实时接收植物图像,并快速给出病虫害的检测结果。 8. **持续学习**:随着时间的推移,系统可以不断学习新的病虫害样本,以提高其识别能力。 9. **用户界面**:为了方便用户使用,通常会有一个用户友好的界面,显示检测结果,并提供进一步的指导或建议。 这项技术的优势在于它可以快速、准确地识别出病虫害,甚至在早期阶段就能发现问题,从而及时采取措施。此外,它还可以减少对化学农药的依赖,支持可持续农业发展。随着技术的不断进步,图像识别在病虫害检测中的应用将越来越广泛。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值