本题要求实现一个函数,统计学生学号链表中专业为计算机的学生人数。链表结点定义如下:
struct ListNode {
char code[8];
struct ListNode *next;
};
这里学生的学号共 7 位数字,其中第 2、3 位是专业编号。计算机专业的编号为 02。
函数接口定义:
int countcs( struct ListNode *head );
其中 head 是用户传入的学生学号链表的头指针;函数 countcs 统计并返回 head 链表中专业为计算机的学生人数。
裁判测试程序样例:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct ListNode {
char code[8];
struct ListNode *next;
};
struct ListNode *createlist(); /*裁判实现,细节不表*/
int countcs( struct ListNode *head );
int main()
{
struct ListNode *head;
head = createlist();
printf("%d\n", countcs(head));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
1021202
2022310
8102134
1030912
3110203
4021205
#
输出样例:
3
来源:
来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/13/exam/problems/606
提交:
题解:
/*
* 统计学生学号链表中专业为计算机的学生人数
*/
int countcs(struct ListNode *head) {
int result = 0;
while (head) {
// 符合计算机专业代码 "02"
if (head->code[1] == '0' && head->code[2] == '2') {
result++;
}
head = head->next;
}
return result;
}