关于循环链表的查早最小元素然后输出删除--直至删完

#include <stdio.h>
#include <malloc.h>

typedef struct Node 
{
    int data;
    struct Node *next;
}Node;

Node *first;

void List()
{
	first = (struct Node *)malloc(sizeof(struct Node));
	first->next = first;
}

void Insert(int val)
{
	Node *n = (struct Node *)malloc(sizeof(struct Node));
	n->data = val;
	Node *temp=first;
	while (temp->next!=first)
		temp = temp->next;
	n->next = temp->next;
	temp->next = n;
}

// 删除并打印
void DeleteAndPrint()
{
        int min;
	Node *Head=first;//用Head标注开始位置
	while (first->next!=first)//看是不是就还剩一个元素
    {
        Node *pre=first,*p=first->next,*premin=pre,*min=p;
        while(p!=Head)//判断循环是否已经完全遍历链表
        {
            if(min->data>p->data)
            {
                min=p;
                premin=pre;//记住最小元素所在位置的前驱结点
            }
            pre=p;
            p=p->next;
        }
        Node *temp=min;//标注最小结点
        printf("%d ",min->data);
        premin->next=min->next;
        free(temp);//释放节点空间
	}
	free(first);// write your code here
    
}

int main()
{
	List();
	int val;
	scanf("%d", &val);
	while (val!=-1)
	{
		Insert(val);
		scanf("%d", &val);
	}

	DeleteAndPrint();
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值