前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >1038 统计同成绩学生 (20 分)

1038 统计同成绩学生 (20 分)

作者头像
可爱见见
发布2019-09-25 16:35:19
4260
发布2019-09-25 16:35:19
举报
文章被收录于专栏:卡尼慕卡尼慕

1038 统计同成绩学生 (20 分)

本题要求读入 N 名学生的成绩,将获得某一给定分数的学生人数输出。

输入格式:

输入在第 1 行给出不超过 105 的正整数 N,即学生总人数。随后一行给出 N 名学生的百分制整数成绩,中间以空格分隔。最后一行给出要查询的分数个数 K(不超过 N 的正整数),随后是 K 个分数,中间以空格分隔。

输出格式:

在一行中按查询顺序给出得分等于指定分数的学生人数,中间以空格分隔,但行末不得有多余空格。

输入样例:

代码语言:javascript
复制
10
60 75 90 55 75 99 82 90 75 50
3 75 90 88

输出样例:

代码语言:javascript
复制
3 2 0

【我的代码】

代码语言:javascript
复制
// 1038 统计同成绩学生 (20 分).cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <iostream>
#include <stdio.h>
using namespace std;
int main()
{
    int num_stu;//学生总人数
    scanf("%d", &num_stu);
    int a[101] = { 0 };//成绩数组
    int tmp;
    for (int i = 0; i < num_stu; i++) {
        scanf("%d", &tmp);
        a[tmp]++;
    }
    int num;//查找个数
    scanf("%d", &num);
    int temp;
    for (int i = 0; i < num; i++) {
        scanf("%d", &temp);
        cout << a[temp];
        if (i != num -1)
            cout << " ";
    }
    return 0;
}

【总结】

  1. 很常规的一个数组运用的问题,巧妙地利用索引带来地查找便利,毕竟数组通过索引查找的时间复杂度是O(1)呢!
  2. 第一次提交失败,错在0-100,总共101个数,我只申请了100的数组空间。改完这个错后还剩最后一个测试点没通过,原因是超时了。
  3. 方法用的已经很巧妙,为啥还会超时呢?哎。。果然cin,cout还是很耗时,直接全部改成scanf就完全通过了。不要再使用cin了!
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-09-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 卡尼慕 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 输入格式:
  • 输出格式:
  • 输入样例:
  • 输出样例:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档