本题要求实现一个函数,统计学生学号链表中专业为计算机的学生人数。链表结点定义如下:
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
作者: 张泳
单位: 浙江大学城市学院
时间限制: 400 ms
内存限制: 64 MB
代码长度限制: 16 KB
编译器 (1)
C (gcc)
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct ListNode {
char code[8];
struct ListNode *next;
};
//struct ListNode *createlist(); /*裁判实现,细节不表*/
struct ListNode *createlist(struct ListNode *head, char temp[]);
int countcs( struct ListNode *head );
int main()
{
struct ListNode *head;
//
head = NULL;
char temp[8]={};
do{
scanf("%s",temp);
if(temp[0] != '#'){
head = createlist(head, temp);
}
}while(temp[0] != '#');
// head = createlist();
printf("%d\n", countcs(head));
return 0;
}
/* 空参的我写不来,写了个有参的。为保证运行,将原题做了相应修改。 */
struct ListNode *createlist(struct ListNode *head, char temp[])
{
//add to linked-list
struct ListNode *p;
p = (struct ListNode*)malloc(sizeof(struct ListNode));
strcpy(p->code, temp);
p->next = NULL;
//find the last
struct ListNode *last = head;
if(last){
if(last->next){
last = last->next;
}
//attach
last->next = p;
}else{
head = p;
}
return head;
}
/* 你的代码将被嵌在这里 */
int countcs( struct ListNode *head )
{
int cnt=0;
struct ListNode *p;
p = head;
while(p){
if(p->code[1]=='0' && p->code[2]=='2')
cnt++;
p = p->next;
}
return cnt;
}