本题要求实现一个函数,统计计算机专业的学生人数。学生学号存储在单链表中,通过识别学号来判断该学生是否为计算机专业的学生,学生的学号共7位数字,其中第2、3位是专业编号,计算机专业的编号为02。例如,‘8026823’则为计算机专业学生,‘8062391’为非计算机专业学生。
链表结点定义:
struct ListNode {
char code[8];
struct ListNode *next;
};
函数接口定义:
int countcs( struct ListNode *head );
其中 head
是用户传入的学生学号链表的头指针;函数countcs统计并返回head链表中专业为计算机的学生人数。
裁判测试程序样例:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct ListNode {
char code[8];
struct ListNode *next;
}ListNode,*Linklist;
Linklist createlist()
{
Linklist head, p, q;
char s[8];
scanf("%s",s);
head = (Linklist)malloc(sizeof(ListNode ));
p = head;
while(s[0]!='#')
{
q = (Linklist)malloc