学生平均成绩的链表程序
Linked list program for student average
我是C编程新手,尤其是链表。有人可以帮我处理我的代码吗?当我编译程序时没有错误,但是当我尝试 运行 程序时它的输出是错误的。不知道是存储错误还是打印错误
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* self-referential structure */
struct listNode {
char name[80];
char subject[80]; /* each listNode contains a character */
float unit;
float grade;
struct listNode *nextPtr; /* pointer to next node */
}; /* end structure listNode */
typedef struct listNode ListNode; /* synonym for struct listNode */
typedef ListNode *ListNodePtr; /* synonym for ListNode* */
/* prototypes */
void insert(ListNodePtr *sPtr, char SUB[80], float grade, float unit, char NAME[80]);
int isEmpty(ListNodePtr sPtr);
void printList(ListNodePtr currentPtr, ListNodePtr *sPtr);
void instructions(void);
int main(void)
{
ListNodePtr startPtr = NULL; /* initially there are no nodes */
int choice; /* user's choice */
float grades, units;
char subn[80], stdn[80];
int i, j, std = 0, sub = 0;
instructions(); /* display the menu */
printf("? ");
scanf("%d", &choice);
/* loop while user does not choose 3 */
while (choice != 3) {
switch (choice) {
case 1: /* input data */
printf("Number of Students: (at least 5 students)\n");
scanf("%d", &std);
for (i = 0; i < std; i++) {
printf("\nStudent name: ");
scanf("%s", &stdn);
printf("How many subjects?\n");
scanf("%d", &sub);
for (j = 0; j < sub; j++) {
printf("\nSubject: ");
scanf("%s", &subn);
printf("Units: ");
scanf("%f", &units);
printf("Final Grade: ");
scanf("%f", &grades);
insert(&startPtr, subn, grades, units, stdn);
}
}
break;
case 2:
printList(startPtr, &startPtr);
break;
default:
printf("Invalid choice.\n\n");
instructions();
break;
} /* end switch */
printf("\n\n? ");
scanf("%d", &choice);
} /* end while */
printf("End of run.\n");
return 0; /* indicates successful termination */
} /* end main */
/* display program instructions to user */
void instructions(void)
{
printf("Enter your choice:\n"
" 1 to Input Student Data.\n"
" 2 to Display Student Data.\n"
" 3 to end.\n");
} /* end function instructions */
/* for series */
void insert(ListNodePtr *sPtr, char SUB[80], float grade, float unit, char NAME[80])
{
ListNodePtr newPtr; /* pointer to new node */
ListNodePtr previousPtr; /* pointer to previous node in list */
ListNodePtr currentPtr; /* pointer to current node in list */
newPtr = malloc(sizeof(ListNode)); /* create node */
if (newPtr != NULL) { /* is space available */
strcpy(newPtr->name, NAME);
strcpy(newPtr->subject, SUB); /* place value in node */
newPtr->grade = grade;
newPtr->unit = unit;
newPtr->nextPtr = NULL; /* node does not link to another node */
previousPtr = NULL;
currentPtr = *sPtr;
/* insert new node at beginning of list */
if (previousPtr == NULL) {
newPtr->nextPtr = *sPtr;
*sPtr = newPtr;
} /* end if */
else { /* insert new node between previousPtr and currentPtr */
previousPtr->nextPtr = newPtr;
newPtr->nextPtr = currentPtr;
} /* end else */
} /* end if */
else {
printf("Student data not inserted. No memory available.\n");
} /* end else */
} /* end function insert */
int isEmpty(ListNodePtr sPtr)
{
return sPtr == NULL;
} /* end function isEmpty */
/* Print the list */
void printList(ListNodePtr currentPtr, ListNodePtr *sPtr)
{
float total = 0.00, total2 = 0.00;
/* if list is empty */
if (currentPtr == NULL) {
printf("List is empty.\n\n");
} /* end if */
else {
printf("\n");
printf("%-20s\t%s\t%s\n", "Subject", "Units", "Final Grade");
/* while not the end of the list */
while (currentPtr != NULL) {
printf("Student Name: %s\n", currentPtr->name);
printf("%-20s\t%.2f\t%.2f\n", currentPtr->subject, currentPtr->unit, currentPtr->grade);
total += currentPtr->unit;
total2 += currentPtr->unit*currentPtr->grade;
currentPtr = currentPtr->nextPtr;
} /* end while */
printf("\nWeight: %.2f", total2 / total);
printf("\n////////////////////////////////////////////////////");
} /* end else */
} /* end function printList */
标题
你好,
我没有仔细查看代码。但是,快速浏览一下,我发现了以下基本问题
nextPtr 应该是一个指针,你正在创建一个实例并复制下一个结构的内容。这效率不高。
我将声明如下
struct listNode *nextPtr; / 指向下一个节点的指针 */
同样,我将更改以下typedef ListNode ListNodePtr;
typedef ListNode ListNodePtr;
到
typedef ListNode *ListNodePtr;
尝试用它重构你的代码,看看效果如何。如果帮不上忙,晚上再详细看看
我是C编程新手,尤其是链表。有人可以帮我处理我的代码吗?当我编译程序时没有错误,但是当我尝试 运行 程序时它的输出是错误的。不知道是存储错误还是打印错误
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* self-referential structure */
struct listNode {
char name[80];
char subject[80]; /* each listNode contains a character */
float unit;
float grade;
struct listNode *nextPtr; /* pointer to next node */
}; /* end structure listNode */
typedef struct listNode ListNode; /* synonym for struct listNode */
typedef ListNode *ListNodePtr; /* synonym for ListNode* */
/* prototypes */
void insert(ListNodePtr *sPtr, char SUB[80], float grade, float unit, char NAME[80]);
int isEmpty(ListNodePtr sPtr);
void printList(ListNodePtr currentPtr, ListNodePtr *sPtr);
void instructions(void);
int main(void)
{
ListNodePtr startPtr = NULL; /* initially there are no nodes */
int choice; /* user's choice */
float grades, units;
char subn[80], stdn[80];
int i, j, std = 0, sub = 0;
instructions(); /* display the menu */
printf("? ");
scanf("%d", &choice);
/* loop while user does not choose 3 */
while (choice != 3) {
switch (choice) {
case 1: /* input data */
printf("Number of Students: (at least 5 students)\n");
scanf("%d", &std);
for (i = 0; i < std; i++) {
printf("\nStudent name: ");
scanf("%s", &stdn);
printf("How many subjects?\n");
scanf("%d", &sub);
for (j = 0; j < sub; j++) {
printf("\nSubject: ");
scanf("%s", &subn);
printf("Units: ");
scanf("%f", &units);
printf("Final Grade: ");
scanf("%f", &grades);
insert(&startPtr, subn, grades, units, stdn);
}
}
break;
case 2:
printList(startPtr, &startPtr);
break;
default:
printf("Invalid choice.\n\n");
instructions();
break;
} /* end switch */
printf("\n\n? ");
scanf("%d", &choice);
} /* end while */
printf("End of run.\n");
return 0; /* indicates successful termination */
} /* end main */
/* display program instructions to user */
void instructions(void)
{
printf("Enter your choice:\n"
" 1 to Input Student Data.\n"
" 2 to Display Student Data.\n"
" 3 to end.\n");
} /* end function instructions */
/* for series */
void insert(ListNodePtr *sPtr, char SUB[80], float grade, float unit, char NAME[80])
{
ListNodePtr newPtr; /* pointer to new node */
ListNodePtr previousPtr; /* pointer to previous node in list */
ListNodePtr currentPtr; /* pointer to current node in list */
newPtr = malloc(sizeof(ListNode)); /* create node */
if (newPtr != NULL) { /* is space available */
strcpy(newPtr->name, NAME);
strcpy(newPtr->subject, SUB); /* place value in node */
newPtr->grade = grade;
newPtr->unit = unit;
newPtr->nextPtr = NULL; /* node does not link to another node */
previousPtr = NULL;
currentPtr = *sPtr;
/* insert new node at beginning of list */
if (previousPtr == NULL) {
newPtr->nextPtr = *sPtr;
*sPtr = newPtr;
} /* end if */
else { /* insert new node between previousPtr and currentPtr */
previousPtr->nextPtr = newPtr;
newPtr->nextPtr = currentPtr;
} /* end else */
} /* end if */
else {
printf("Student data not inserted. No memory available.\n");
} /* end else */
} /* end function insert */
int isEmpty(ListNodePtr sPtr)
{
return sPtr == NULL;
} /* end function isEmpty */
/* Print the list */
void printList(ListNodePtr currentPtr, ListNodePtr *sPtr)
{
float total = 0.00, total2 = 0.00;
/* if list is empty */
if (currentPtr == NULL) {
printf("List is empty.\n\n");
} /* end if */
else {
printf("\n");
printf("%-20s\t%s\t%s\n", "Subject", "Units", "Final Grade");
/* while not the end of the list */
while (currentPtr != NULL) {
printf("Student Name: %s\n", currentPtr->name);
printf("%-20s\t%.2f\t%.2f\n", currentPtr->subject, currentPtr->unit, currentPtr->grade);
total += currentPtr->unit;
total2 += currentPtr->unit*currentPtr->grade;
currentPtr = currentPtr->nextPtr;
} /* end while */
printf("\nWeight: %.2f", total2 / total);
printf("\n////////////////////////////////////////////////////");
} /* end else */
} /* end function printList */
标题
你好, 我没有仔细查看代码。但是,快速浏览一下,我发现了以下基本问题
nextPtr 应该是一个指针,你正在创建一个实例并复制下一个结构的内容。这效率不高。 我将声明如下
struct listNode *nextPtr; / 指向下一个节点的指针 */
同样,我将更改以下typedef ListNode ListNodePtr; typedef ListNode ListNodePtr;
到 typedef ListNode *ListNodePtr;
尝试用它重构你的代码,看看效果如何。如果帮不上忙,晚上再详细看看