zoukankan      html  css  js  c++  java
  • 1948-参赛选手信息更新问题

    描述

     

          所有题目(Word、PDF格式):http://acm.njupt.edu.cn/acmhome/nuptacm/2013HW.zip

    根据题目A的问题描述,我们知道2013“华为杯”南京邮电大学大学生团体歌唱大赛要求每个参赛团体由3名同一年级在校学生选手组成,各位同学踊跃报名,赛事组委会收到大量参赛团体信息,包括每一个团体选手姓名、学号、年级、联系方式等。

    因最近流感来袭,大赛组委会根据选手建议,决定将赛事推迟到秋季。该项决定带来的问题是:参赛团体的年级信息需要更新,其中已毕业离校参赛团队的信息需要删除。

    我们将问题进行简化,大学一年级至四年级的信息依次用0、1、2、3表示,硕士研究生一年级至三年级的信息依次用4、5、6表示,给定参赛团体的年级信息,请你输出更新后的年级信息,如果选手已毕业,则无需输出。这里我们规定,参赛团体每位选手都正常升级或毕业,原来大学四年级或硕士研究生三年级的选手一律认为已毕业了。

    输入

    输入包括多个测试用例,首先给出测试用例数N,接着给出N个测试用例,每一个测试用例包括1行,首先给出参赛团体总数M,再依次给出M个参赛团体的年级信息,1≤N≤1000,1≤M≤1000。

    输出

    输出包括多行,对于每个测试用例输出一行,依次输出更新后的年级信息,如果选手已毕业,则无需输出。

    样例输入

    2

    5 1 2 4 5 6

    4 0 0 6 6

    样例输出

    2 3 5 6

    1 1

    #include <iostream>
    using namespace std;
    int main()
    {
        int n,m,*a;
        cin>>n;
        int i,j,k;
        for(i=0;i<n;i++)
        {
            cin>>m;
            a=(int*)malloc(m*sizeof(int));
            for(k=0;k<m;k++) cin>>a[k];
            for(j=0;j<m;j++)
            {
                if(a[j]!=3&&a[j]!=6)
                {
                    cout<<a[j]+1;
                    break;
                }
            }
            for(k=j+1;k<m;k++)
            {
                if(a[k]!=3&&a[k]!=6)
                    cout<<" "<<a[k]+1;        
            }
            cout<<endl;
        }
        return 0;
    }
    

      

  • 相关阅读:
    SOJ4478 Easy Problem II(模拟、栈)
    SOJ4480 Easy Problem IV (并查集)
    暴力枚举法总结
    区间DP学习总结
    51nod 1019 逆序数(逆序数+离散化)
    win7系统查看硬盘序列号步骤
    雷达图制作方法
    matlab更改打开时候默认路径
    excel多组数据散点图生成
    EndNote(三)之中文引文导入方式
  • 原文地址:https://www.cnblogs.com/Rosanna/p/3438634.html
Copyright © 2011-2022 走看看