UVa 409 - Excuses, Excuses!

题目:有一些关键词,还有一些说明理由的句子。输出关键词出现最多次数的句子,若有多个都输出。

分析:字符串。把句子拆成单词,依次和所有关键词比较即可。

             处理时注意,必须是关键词匹配,不能使前缀。

说明:同以关键词多次出现,按多次计算;每组结束都有换行。

#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>

using namespace std;

char keywords[24][24];
char excuses[24][80];
int  counts[24];

int small( char a )
{
	if ( a >= 'A' && a <= 'Z' )
		return a +'a'-'A';
	else return a;
}

int find_word( char *a, char *b )
{
	char buf[80];
	int  count = 0,move = 0;
	while ( a[move] ) {
		while ( a[move] && (small(a[move]) < 'a' || small(a[move]) > 'z') )
			move ++;
		int save = 0;
		while ( small(a[move]) >= 'a' && small(a[move]) <= 'z' )
			buf[save ++] = small(a[move ++]);
		buf[save] = 0;
		count += !strcmp(b,buf);
	}
	return count;
}

int main()
{
	int n,m,T = 1;
	while ( ~scanf("%d%d",&n,&m) ) {
		//getchar();
		for ( int i = 0 ; i < n ; ++ i ) {
			scanf("%s",keywords[i]);
			getchar();
		}
		for ( int i = 0 ; i < m ; ++ i ) {
			gets(excuses[i]);
			counts[i] = 0;
		}
		
		int max = 0;
		for ( int i = 0 ; i < m ; ++ i ) {
			for ( int j = 0 ; j < n ; ++ j )
				counts[i] += find_word( excuses[i], keywords[j] );
			if ( max < counts[i] )
				max = counts[i];
		}
		
		printf("Excuse Set #%d\n",T ++);
		for ( int i = 0 ; i < m ; ++ i )
			if ( counts[i] == max )
				printf("%s\n",excuses[i]);
		printf("\n");
	}
	return 0;
}

以下是一个简单的学生请假管理系统的代码示例,使用Python语言编写,采用了基本的面向对象编程思想: ```python class Student: def __init__(self, name, id): self.name = name self.id = id self.absences = 0 self.excuses = [] def add_excuse(self, excuse): self.excuses.append(excuse) def get_excuses(self): return self.excuses def add_absence(self): self.absences += 1 def get_absences(self): return self.absences class AttendanceSystem: def __init__(self): self.students = [] def add_student(self, student): self.students.append(student) def get_student(self, id): for student in self.students: if student.id == id: return student return None def mark_absence(self, id): student = self.get_student(id) if student: student.add_absence() def add_excuse(self, id, excuse): student = self.get_student(id) if student: student.add_excuse(excuse) def get_student_report(self, id): student = self.get_student(id) if student: report = "Student Name: {}\nStudent ID: {}\nAbsences: {}\nExcuses: {}\n".format(student.name, student.id, student.absences, student.get_excuses()) return report return None ``` 以上代码定义了两个类:`Student`和`AttendanceSystem`。`Student`类代表一个学生,包含了学生的姓名、学号、缺勤次数和请假记录;`AttendanceSystem`类代表整个请假管理系统,包含了所有学生的信息和管理操作。 使用这个代码示例,你可以创建学生对象并添加到请假管理系统中,记录学生的缺勤次数和请假记录,以及查询某个学生的请假报告。你可以根据自己的需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值