gpt4 book ai didi

c - 在 CPU 调度模拟 C 程序(SJF)中,当节点放在 "queue"上时,如何按链表中的 CPU 时间对节点进行排序?

转载 作者:行者123 更新时间:2023-11-30 16:10:20 24 4
gpt4 key购买 nike

下面是我的问题的两个相关函数,但请询问您是否需要任何其他函数来帮助我解决这个问题。该程序模拟具有指数间隔时间、指数服务时间和 FCFS 调度规则的单个服务器队列。这是一个分配,我打算通过按 CPU_time 对队列列表进行排序来修改它以使用 SJF 调度。这是我对冒泡排序的尝试,但是当它运行时,它没有进入 do-while 循环。添加链接列表时对链接列表进行排序的最佳方法是什么?

/*********************************************************************/
/* Name: Puton_queue */
/* Description */
/* This procedure inserts a customer at the end of the given */
/* queue. The parameters are as follows: */
/* pqueue - pointer to the queue. */
/* pcust - index of the customer to be inserted. */
/* The procedure performs the following steps: */
/* 1 - get a free node for the customer. */
/* 2 - inset the node ar the end of the queue. */
/* 2a - into an empty queue */
/* 2b - normal insertion */
/*********************************************************************/
void Puton_queue(struct Queue_struct *pqueue, struct Custs *pcust, struct Custs *CPU_time)
{
struct Queue *newnode;
/* get an new node */

printf(" My CPUTIME is %ld:\n", CPU_time);

newnode = (struct Queue *) malloc(sizeof(struct Queue));
/* now loc is the index of a free node in queue */
/* put information in the node */
newnode->cust_index = pcust;
newnode->CPU_time=CPU_time;
newnode->next = NULL;
/* check to see if the queue is initially empty */
if(pqueue->q_last == NULL)
{
pqueue->q_head = newnode;
pqueue->q_last = newnode;
return;
}
/* otherwise add it to the end of the queue and relink */
pqueue->q_last->next = newnode;
pqueue->q_last = newnode;

int i;
bool swapped=TRUE;
struct Queue *currentnode;
struct Queue *lastnode = NULL;

do
{
swapped = TRUE;
currentnode = pqueue->q_head;
printf("nodeIME is %ld:\n", currentnode->CPU_time);
while(currentnode->next != lastnode)
{
if(currentnode->CPU_time < currentnode->next->CPU_time)
{
swap(currentnode, currentnode->next);
swapped = FALSE;
}
}
lastnode = currentnode;
}
while(swapped);

return;
}


/*********************************************************************/
/* Name: swap */
/* Description */
/* This function is used to swap two nodes in the queue list */
/*********************************************************************/
void swap(struct Queue *a, struct Queue *b)
{
struct Queue *tem;

tem = a->cust_index;
a->cust_index = b->cust_index;
b->cust_index = tem;

tem = a->next;
a->next = b->next;
b->next = tem;
}

最佳答案

这真的很有趣,我刚刚做了一个与此类似的作业。不要将新节点添加到队列末尾。只需在插入它们时将它们添加到需要的位置即可。遍历列表,直到找到一个 CPU 时间小于(或大于,取决于您想要的方式)您要推送的节点,并将其插入那里。

这意味着您可能必须检查node->next->next->cpuTime,因为您希望将其推送到两个节点之间。

我希望我正确理解了这个问题。祝你好运。

关于c - 在 CPU 调度模拟 C 程序(SJF)中,当节点放在 "queue"上时,如何按链表中的 CPU 时间对节点进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58906947/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com