17 软专

给定一个带表头结点的双向链表L,每个结点有4个数据成员:前驱结点的指针LLink,后继结点的指针RLink,数据的成员Data,和访问频度Freq;且已知双向链表L中结点一直按访问频度递减的顺序排列,即频繁访问的结点总是靠近表头:初始状态L中所有结点的Freq都为0。
对双链表L的Locata(x)操作:每操作一次,将数据值为x的结点访问频度Freq加1.请设计一个算法实现对双链表L的Locate(x)操作,要求操作后L中结点仍按照访问频度的递减顺序排列。

思路:先从前往后遍历找到值为x的结点,然后再从头进行插入排序,找到插入位置。(注意不是循环链表,只是双向链表)

typedef struct node
{
	int data;
	struct node *LLink,*RLink;
	int Freq;
}*list;
void locate(list L,int x)
{
	list p=L->RLink,q;
	while(p!=NULL)
	{
		if(p->data==x)
		{
			p->Freq++;
			break;
		}
		p=p->RLink;
	}
	if(p->LLink==L)return;//如果p是第一个结点则不处理
	else
	{
		p->LLink->RLink=p->RLink;//将p去除
		if(p->RLink!=NULL)
			p->RLink->LLink=p->LLink;
		q=L->RLink;//找到p的插入位置
		while(q!=NULL&&q->Freq>p->Freq)
		{
			q=q->RLink;
		}
		q->LLink->RLink=p;//p插入到q之前
		p->LLink=q->LLink;
		q->LLink=p;
		p->RLink=q;
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值