2013年第三届“华为杯”南邮程序设计竞赛—参赛选手信息更新问题

题目B:参赛选手信息更新问题

时间限制(普通/Java):2000MS/6000MS          运行内存限制:65536KByte

问题描述

 

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

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

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

 

问题输入

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

问题输出

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

 

样例输入

2

5 1 2 4 5 6

4 0 0 6 6

样例输出

2 3 5 6

1 1

 

提示

本题纯属虚构,题目中输入数据和输出数据在一行中均以空格分隔,赛后酌情进行重新测试。

本人代码,仅供参考:

#include<stdio.h>

#include<stdlib.h>


int main()
{
    int count,i,a,*p,*q;
    int z=0;
    int j=0;
    scanf("%d",&count);
    p=(int *)malloc(10*sizeof(int));
    while(count--&&scanf("%d",&a))
       
        q=(int *)malloc(a*sizeof(int));
    
        for(i=0;i<a;i++) 
        {
            scanf("%d",&q[i]);
            if(q[i]<6)
                p[j++]=q[i]+1;
        }
        if(count==1)
           j++;
            i=j;
        }
        
    }
    
        for(z=0;z<j;z++)    
        {
            if(z==i)
                printf("\n");
            else
                printf("%d ",p[z]);
        }
    
        return 0;
}

posted @ 2013-05-11 22:17  dreamsyeah  阅读(194)  评论(0编辑  收藏  举报