ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

1004 成绩排名 (20 分)(memcpy函数)

2022-01-11 12:58:19  阅读:182  来源: 互联网

标签:成绩排名 1004 15 姓名 成绩 20 sizeof include memcpy


读入 n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。

输入格式:

每个测试输入包含 1 个测试用例,格式为
第 1 行:正整数 n
第 2 行:第 1 个学生的姓名 学号 成绩
第 3 行:第 2 个学生的姓名 学号 成绩
… … …
第 n+1 行:第 n 个学生的姓名 学号 成绩
其中姓名和学号均为不超过 10 个字符的字符串,成绩为 0 到 100 之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。

输出格式:

对每个测试用例输出 2 行,第 1 行是成绩最高学生的姓名和学号,第 2 行是成绩最低学生的姓名和学号,字符串间有 1 空格。

输入样例:

3
Joe Math990112 89
Mike CS991301 100
Mary EE990830 95

输出样例:

Mike CS991301
Joe Math990112

memcpy函数

从源内存地址的起始位置开始拷贝若干个字节到目标内存地址中
用法:memcpy(a , b , sizeof(b))把b中的所有数据都赋值给a

代码:

#include<iostream>
#include<string>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
int main(){
    int n , m ,min1 = 100 , max1 = 0;
    char s[15] , k[15];
    char smin[15] , kmin[15];
    char smax[15] , kmax[15];
    cin>>n;
    while(n--){
        cin>>s>>k>>m;
        if(m > max1){
            max1 = m;
            memcpy(smax , s , sizeof(s));
            memcpy(kmax , k , sizeof(k));
        }
        if(m < min1){
            min1 = m;
            memcpy(smin , s , sizeof(s));
            memcpy(kmin , k , sizeof(k));
        }
    }
    cout<<smax<<" "<<kmax<<endl;
    cout<<smin<<" "<<kmin;
}

在这里插入图片描述

标签:成绩排名,1004,15,姓名,成绩,20,sizeof,include,memcpy
来源: https://blog.csdn.net/runingyoung/article/details/122429695

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有