显示队列删除后的数据
Displaying the data of a queue after its deletion
我正在使用 c 中的结构创建一个队列来存储客户。我可以删除客户节点,但我想显示已删除客户的信息,即姓名和条形码编号
typedef struct customer {
char name[50]; // the customer's name
double barcodeNumber; // the barcode number from the customer's ticket
struct customer *next; // a pointer to the next customer in the queue after this one
}
Customer;
typedef struct eventQueue {
Customer *head; // points to the customer at the front/head of the queue
Customer *tail; // points to the customer at the end/tail of the queue
} EventQueue;
这是我的删除功能
int removeCustomer(EventQueue *qPtr, Customer *c)
{
if(qPtr == NULL)
return INVALID_INPUT_PARAMETER;
if(c == NULL)
return INVALID_INPUT_PARAMETER;
if(qPtr->head == NULL)
return INVALID_QUEUE_OPERATION;
char *name;
double barcode;
strcpy(c->name,name);
barcodeCopy = c->barcode;
c=qPtr->head;
qPtr->head=qPtr->head->next;
free(c);
// Value to be returned if a function is completed successfully
return SUCCESS;
}
这是我对代码的实现
void main()
{
printf("\nAttempting to remove customer from queue..");
// (attempt to) remove / pop a customer from the queue
Customer customerInfo;
// a variable to receive the customer data removed from the queue
result = removeCustomer(pQueue, &customerInfo); // this calls your implementation of removeCustomer()
// if customer wasn't removed successfully
if (result != SUCCESS)
{
printf("ERROR: Unable to remove customer from queue.\n");
}
else
{
printf("..customer removed successfully!\n");
printf("The customer removed was %s who was barcode number %.0lf.\n", customerInfo.name, customerInfo.barcodeNumber);}
}
只需分解 removeCustomer 方法中的操作
从队列中获取“first/front”客户
Customer* first = qPtr->head;
将其数据复制到您作为参数传递的客户信息结构
// using first for clarity but qPtr->head->name also works
strcpy(c->name, first->name);
c->barcodeNumber = first->barcodeNumber;
更新队列 - 删除前面
qPtr->head = qPtr->head->next;
删除第一个客户(现已提取)
free(first);
我正在使用 c 中的结构创建一个队列来存储客户。我可以删除客户节点,但我想显示已删除客户的信息,即姓名和条形码编号
typedef struct customer {
char name[50]; // the customer's name
double barcodeNumber; // the barcode number from the customer's ticket
struct customer *next; // a pointer to the next customer in the queue after this one
}
Customer;
typedef struct eventQueue {
Customer *head; // points to the customer at the front/head of the queue
Customer *tail; // points to the customer at the end/tail of the queue
} EventQueue;
这是我的删除功能
int removeCustomer(EventQueue *qPtr, Customer *c)
{
if(qPtr == NULL)
return INVALID_INPUT_PARAMETER;
if(c == NULL)
return INVALID_INPUT_PARAMETER;
if(qPtr->head == NULL)
return INVALID_QUEUE_OPERATION;
char *name;
double barcode;
strcpy(c->name,name);
barcodeCopy = c->barcode;
c=qPtr->head;
qPtr->head=qPtr->head->next;
free(c);
// Value to be returned if a function is completed successfully
return SUCCESS;
}
这是我对代码的实现
void main()
{
printf("\nAttempting to remove customer from queue..");
// (attempt to) remove / pop a customer from the queue
Customer customerInfo;
// a variable to receive the customer data removed from the queue
result = removeCustomer(pQueue, &customerInfo); // this calls your implementation of removeCustomer()
// if customer wasn't removed successfully
if (result != SUCCESS)
{
printf("ERROR: Unable to remove customer from queue.\n");
}
else
{
printf("..customer removed successfully!\n");
printf("The customer removed was %s who was barcode number %.0lf.\n", customerInfo.name, customerInfo.barcodeNumber);}
}
只需分解 removeCustomer 方法中的操作
从队列中获取“first/front”客户
Customer* first = qPtr->head;
将其数据复制到您作为参数传递的客户信息结构
// using first for clarity but qPtr->head->name also works
strcpy(c->name, first->name);
c->barcodeNumber = first->barcodeNumber;
更新队列 - 删除前面
qPtr->head = qPtr->head->next;
删除第一个客户(现已提取)
free(first);