uva--409-- Excuses, Excuses!

开始用getchar()逐个输入逐个处理结果超时了。。。。。

后面改用getline输入就过了。

思路:就是对每一句话都找一遍看有多少个指定的单词,值得注意的是从

整个语句中挑出每个单词的处理

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string.h>
#include<algorithm>
using namespace std;

int is_char(char x)
{
    if(x>='a'&&x<='z'||x>='A'&&x<='Z')
       return 1;
    else
     return 0;
}

int is_shuzi(char a)
{
    if(a>='0'&&a<='9')
      return 1;
    else
      return 0;
} 

int main()
{
    int cnt[20+1],cnt1=0;
    string s1[20+1],str,s2[20+1],str1;
    char ch,ch1;
    int K,E,i,j,k,k1;
    while(cin>>K>>E)
    {
         cnt1++;
         for(i=0;i<K;i++)
             cin>>s1[i];
         getchar();
         k=-1;k1=-1;
         memset(cnt,0,sizeof(cnt));
         while(E--)
         {
              k++;
              k1++;
              str="";
             getline(cin,s2[k1]);  //不能用cin.getline();
             int len=s2[k1].size();
             for(i=0;i<len;i++) 
              {     ch=s2[k1][i];
                    if(is_char(ch))
                    {
                          if(ch>='A'&&ch<='Z')
                             ch=ch+32;
                          str=str+ch;
                    }
                    if(str[0]>='a'&&str[0]<='z')
                    {
                       if(!is_char(ch)&&!is_shuzi(ch))//多个&&连用出错,所以写成了函数形式 
                       {
                       //cout<<str<<endl;//测试语句 
                          for(j=0;j<K;j++)
                             if(s1[j]==str)
                                cnt[k]++;
                          str="";
                       }
                   }
              }
         } 
         int max=0;j=0;
         for(i=0;i<=k;i++)
            if(max<cnt[i])
            {
               j=i;
               max=cnt[i];
            }
         //cout<<s2[0]<<endl;//测试语句 
         //for(i=0;i<=k;i++)
             //cout<<cnt[i]<<" ";
         //cout<<endl; 
         cout<<"Excuse Set #"<<cnt1<<endl;
         cout<<s2[j]<<endl;
         for(i=0;i<=k;i++)
            if(i!=j&&cnt[i]==max)
              cout<<s2[i]<<endl;
         cout<<endl; 
    }
  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、付费专栏及课程。

余额充值