PAT1036 Boys vs Girls

Sample Input 1:

3
Joe M Math990112 89
Mike M CS991301 100
Mary F EE990830 95
Sample Output 1:
Mary EE990830
Joe Math990112
6
Sample Input 2:
1
Jean M AA980920 60
Sample Output 2:
Absent
Jean AA980920
NA

 

 

 

 

 

 

#include <iostream>
#include <iomanip>
#include <string>
#include <vector>
using namespace std;

struct STUDENT
{
    string name;
    char gender;
    string id;
    int grade;
};

int main()
{
    vector<STUDENT> VMale;
    vector<STUDENT> VFaMale;
    int N;
    cin>>N;
    while(N--)
    {
        STUDENT stu;
        cin>>stu.name>>stu.gender>>stu.id>>stu.grade;
        if (stu.gender == 'M')
        {
            VMale.push_back(stu);
        }
        else
        {
            VFaMale.push_back(stu);
        }
    }
    STUDENT highestFemale;
    int highest = 0;
    if (VFaMale.size() > 0)
    {

        vector<STUDENT>::iterator iterFemale = VFaMale.begin();
        highestFemale = *iterFemale;
        highest = (*iterFemale).grade;
        iterFemale++;
        while (iterFemale != VFaMale.end())
        {
            if ((*iterFemale).grade > highest)
            {
                highestFemale = *iterFemale;
                highest = highestFemale.grade;
            }
            iterFemale++;
        }
        cout<<highestFemale.name<<" "<<highestFemale.id<<endl;
    }
    else
    {
        cout<<"Absent"<<endl;
    }

    STUDENT lowmale;
    int lowest = 0;
    if (VMale.size() > 0)
    {

        vector<STUDENT>::iterator iterFemale = VMale.begin();
        lowmale = *iterFemale;
        lowest = (*iterFemale).grade;
        iterFemale++;
        while (iterFemale != VMale.end())
        {
            if ((*iterFemale).grade < lowest)
            {
                lowmale = *iterFemale;
                lowest = lowmale.grade;
            }
            iterFemale++;
        }
        cout<<lowmale.name<<" "<<lowmale.id<<endl;
    }
    else
    {
        cout<<"Absent"<<endl;
    }

    if (VMale.size() == 0 || VFaMale.size() == 0)
    {
        cout<<"NA";
    }
    else
    {
        cout<<highest - lowest;
    }

    return 0;
}
 
### 关于 PAT 1036 的 C 语言解题思路 针对PAT 1036 题目,可以采用结构化的方法处理输入并解析特定模式的数据。考虑到该类问题通常涉及字符串处理和格式化输入输出,在解答过程中应当充分利用标准库函数如 `sscanf` 和 `printf` 来简化编程逻辑。 #### 使用 sscanf 函数读取数据 为了高效地从给定的输入串中抽取所需的信息,可以借鉴类似的例子[^1]: ```c #include <stdio.h> int main() { char str[] = "42 3.14"; int num; float fnum; sscanf(str, "%d %f", &num, &fnum); printf("Integer: %d\n", num); printf("Float: %f\n", fnum); return 0; } ``` 这段代码展示了如何利用 `sscanf` 函数按照指定格式提取变量值。对于PAT 1036而言,可以根据具体需求调整格式说明符以及目标变量类型,从而适应不同的输入形式。 #### 处理剪切粘贴操作 如果涉及到更复杂的文本编辑功能,则可参考其他相似案例中的实现方式[^3]。例如,通过定义额外的缓冲区保存被剪切的部分,并依据前后缀条件决定插入点的位置;若未找到合适的匹配项,默认将新内容附加到原字符串结尾处。 #### 完整解决方案框架 基于上述分析,这里提供一个适用于PAT 1036的大致解决框架(假设题目要求为简单的数值转换或字符替换),实际编码时需根据官方文档进一步细化各部分细节: ```c #include <stdio.h> #include <string.h> // 主程序入口 int main(){ // 初始化必要的变量... while (scanf("%s", input)!=EOF){ // 对每组测试用例做相应处理 // 输出结果 printf("%s\n", output); } return 0; } ``` 请注意以上仅为模板示意,具体的算法设计还需紧密结合PAT 1036的具体要求来进行优化和完善。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值