• PTA天梯赛座位分配


    天梯赛每年有大量参赛队员,要保证同一所学校的所有队员都不能相邻,分配座位就成为一件比较麻烦的事情。为此我们制定如下策略:假设某赛场有 N 所学校参赛,第 i 所学校有 M[i] 支队伍,每队 10 位参赛选手。令每校选手排成一列纵队,第 i+1 队的选手排在第 i 队选手之后。从第 1 所学校开始,各校的第 1 位队员顺次入座,然后是各校的第 2 位队员…… 以此类推。如果最后只剩下 1 所学校的队伍还没有分配座位,则需要安排他们的队员隔位就坐。本题就要求你编写程序,自动为各校生成队员的座位号,从 1 开始编号。

    输入格式:

    输入在一行中给出参赛的高校数 N (不超过100的正整数);第二行给出 N 个不超过10的正整数,其中第 i 个数对应第 i 所高校的参赛队伍数,数字间以空格分隔。

    输出格式:

    从第 1 所高校的第 1 支队伍开始,顺次输出队员的座位号。每队占一行,座位号间以 1 个空格分隔,行首尾不得有多余空格。另外,每所高校的第一行按“#X”输出该校的编号X,从 1 开始。

    输入样例:

    3
    3 4 2

    输出样例:

    1. #1
    2. 1 4 7 10 13 16 19 22 25 28
    3. 31 34 37 40 43 46 49 52 55 58
    4. 61 63 65 67 69 71 73 75 77 79
    5. #2
    6. 2 5 8 11 14 17 20 23 26 29
    7. 32 35 38 41 44 47 50 53 56 59
    8. 62 64 66 68 70 72 74 76 78 80
    9. 82 84 86 88 90 92 94 96 98 100
    10. #3
    11. 3 6 9 12 15 18 21 24 27 30
    12. 33 36 39 42 45 48 51 54 57 60

    代码实现:

    1. #include
    2. #include
    3. int main()
    4. {
    5. int N;
    6. scanf("%d",&N);
    7. int M[101]={0};
    8. for(int i=1;i<=N;i++)
    9. {
    10. scanf("%d",&M[i]);
    11. }
    12. for(int i=1;i<=N;i++)
    13. {//每个学校
    14. printf("#%d\n",i);
    15. int sum=M[i]*10;
    16. int number=i;//第一队的第一个队员
    17. int cnt=0;
    18. int gap=N;//两个队员之间的座位间隔
    19. if(gap<2)gap=2;
    20. for(int j=1;j<=M[i];j++)
    21. {//每支队伍
    22. int flag=0;
    23. for(int k=1;k<=10;k++)
    24. {
    25. if(flag==0)
    26. {
    27. flag=1;
    28. }
    29. else printf(" ");
    30. printf("%d",number);
    31. cnt++;
    32. if(k==10)//排完一支队伍检查一次
    33. for(int o=1;o
    34. {
    35. if(cnt==M[o]*10&&gap>2)
    36. {
    37. gap--;
    38. }
    39. }
    40. //下一个队员的座位号
    41. number+=gap;
    42. if(k==10)
    43. {//检查后面的队伍学校有没有排完
    44. for(int o=i+1;o<=N;o++)
    45. {
    46. if(cnt==M[o]*10&&gap>2)
    47. {
    48. gap--;
    49. }
    50. }
    51. }
    52. }//排完一支队伍换行
    53. printf("\n");
    54. }
    55. }
    56. return 0;
    57. }

  • 相关阅读:
    HCIP学习笔记-存储服务规划 -4
    基于JAVA考研驿站网站计算机毕业设计源码+系统+mysql数据库+lw文档+部署
    pandas 学习 第15篇:分组 groupby
    SQLite表添加主键
    Linux主机间的相互免秘钥
    CSS 选择器详细分类
    RocketMQ(12)——生产者介绍
    疫情放开,新冠防治药推荐,中医治疫病的准则
    基于SSM的零食小食品商城(零食商城源码)
    java-php-python-ssm心理健康管理系统计算机毕业设计
  • 原文地址:https://blog.csdn.net/Xm041206/article/details/134490200