团体程序设计天梯赛 L1-049. 天梯赛座位分配(测试数据+不同方法)
Data:
/*
3
3 2 1
#1
1 4 7 10 13 16 19 22 25 28
31 33 35 37 39 41 43 45 47 49
51 53 55 57 59 61 63 65 67 69
#2
2 5 8 11 14 17 20 23 26 29
32 34 36 38 40 42 44 46 48 50
#3
3 6 9 12 15 18 21 24 27 30
2
1 2
#1
1 3 5 7 9 11 13 15 17 19
#2
2 4 6 8 10 12 14 16 18 20
22 24 26 28 30 32 34 36 38 40
1
3
#1
1 3 5 7 9 11 13 15 17 19
21 23 25 27 29 31 33 35 37 39
41 43 45 47 49 51 53 55 57 59
*/
Way1 数组:
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- #include <cmath>
- #include <stdbool.h>
- #include <set>
- #include <vector>
- #include <map>
- #include <algorithm>
- using namespace std;
- long f[][],g[],a[];
- int main()
- {
- long n,i,j,num,c,pos;
- scanf("%ld",&n);
- for (i=;i<=n;i++)
- {
- scanf("%ld",&a[i]);
- a[i]*=;
- g[i]=;
- }
- c=n;
- num=;
- pos=;
- while (c>)
- {
- for (i=;i<=n;i++)
- if (g[i]!=a[i])
- {
- num++;
- g[i]++;
- f[i][g[i]]=num;
- if (g[i]==a[i])
- c--;
- pos=i;
- }
- }
- if (c==)
- {
- for (j=;j<=n;j++)
- if (g[j]!=a[j])
- break;
- if (pos!=j)
- num++;
- else
- num+=;
- g[j]++;
- f[j][g[j]]=num;
- for (i=g[j]+;i<=a[j];i++)
- {
- num+=;
- g[j]++;
- f[j][g[j]]=num;
- }
- }
- for (i=;i<=n;i++)
- {
- printf("#%ld\n",i);
- for (j=;j<=a[i];j++)
- {
- printf("%ld",f[i][j]);
- if (j%==)
- printf("\n");
- else
- printf(" ");
- }
- }
- return ;
- }
Way2 链环:
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- #include <cmath>
- #include <stdbool.h>
- #include <set>
- #include <vector>
- #include <map>
- #include <algorithm>
- using namespace std;
- //Á´»·
- struct node
- {
- long a,b;
- struct node *next,*pre;
- }*q,*p,*r;
- long sch[][],g[];
- int main()
- {
- long n,i,j,d,num=;
- bool vis;
- q=NULL;
- scanf("%ld",&n);
- for (i=;i<=n;i++)
- {
- scanf("%ld",&d);
- p=(struct node *) malloc (sizeof(struct node));
- p->a=i;
- p->b=d*;
- if (q==NULL)
- q=p;
- else
- {
- r->next=p;
- p->pre=r;
- }
- r=p;
- }
- r->next=q;
- q->pre=r;
- vis=false;
- p=q;
- while ()
- {
- if (p->a==p->next->a && vis)
- num+=;
- else
- num++;
- g[p->a]++;
- sch[p->a][g[p->a]]=num;
- p->b--;
- vis=true;
- if (p->b==)
- {
- if (p->a==p->next->a)
- break;
- else
- {
- p->pre->next=p->next;
- p->next->pre=p->pre;
- if (p->pre->a==p->next->a)
- vis=false;
- }
- }
- p=p->next;
- }
- for (i=;i<=n;i++)
- {
- printf("#%ld\n",i);
- for (j=;j<=g[i];j++)
- {
- printf("%ld",sch[i][j]);
- if (j%==)
- printf("\n");
- else
- printf(" ");
- }
- }
- return ;
- }
Way3 vector:
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- #include <cmath>
- #include <stdbool.h>
- #include <set>
- #include <vector>
- #include <map>
- #include <algorithm>
- using namespace std;
- vector<pair<int,int> > f;
- vector<int> sch[];
- int main()
- {
- long n,a,num,pre,i;
- vector<pair<int,int> >::iterator j;
- vector<int>::iterator k;
- scanf("%ld",&n);
- for (i=;i<=n;i++)
- {
- scanf("%ld",&a);
- f.push_back(make_pair(a*,i));
- }
- num=;
- pre=-;
- while (!f.empty())
- {
- for (j=f.begin();j!=f.end();j++)
- {
- if (pre==j->second)
- num+=;
- else
- num++;
- sch[j->second].push_back(num);
- pre=j->second;
- j->first--;
- if (j->first==)
- {
- f.erase(j);
- j--;
- }
- }
- }
- for (i=;i<=n;i++)
- {
- printf("#%ld\n",i);
- for (k=sch[i].begin(),a=;k!=sch[i].end();k++,a++)
- {
- printf("%ld",*k);
- if (a%==)
- printf("\n");
- else
- printf(" ");
- }
- }
- return ;
- }
团体程序设计天梯赛 L1-049. 天梯赛座位分配(测试数据+不同方法)的更多相关文章
- PAT L1 049 天梯赛座位分配
天梯赛每年有大量参赛队员,要保证同一所学校的所有队员都不能相邻,分配座位就成为一件比较麻烦的事情.为此我们制定如下策略:假设某赛场有 N 所学校参赛,第 i 所学校有 M[i] 支队伍,每队 10 位 ...
- 团体程序设计天梯赛(CCCC) L3021 神坛 的一些错误做法(目前网上的方法没一个是对的) 和 一些想法
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3019 代码排版 方法与编译原理密切相关,只有一个测试点段错误
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3015 球队“食物链” 状态压缩
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code #include <cstdio> #include ...
- 团体程序设计天梯赛(CCCC) L3014 周游世界 BFS证明
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3013 非常弹的球 不同思路
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3012 水果忍者 上凸或下凹的证明
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code #include <cstdio> #include ...
- 团体程序设计天梯赛(CCCC) L3009 长城 方法证明
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 树状数组+二分答案查询第k大的数 (团体程序设计天梯赛 L3-002. 堆栈)
前提是数的范围较小 1 数据范围:O(n) 2 查第k大的数i:log(n)(树状数组查询小于等于i的数目)*log(n)(二分找到i) 3 添加:log(n) (树状数组) 4 删除:log(n) ...
随机推荐
- 04-matplotlib-柱形图
import numpy as np import matplotlib.pyplot as plt # 柱形图 # 例一 N =5 y = [15,28,10,30,25] index = np.a ...
- ossec兼容的操作系统
OSSEC兼容以下操作系统和日志格式 操作系统 以下操作系统可安装OSSEC代理 l GNU/Linux (all distributions, including RHEL, Ubuntu, Sl ...
- Annotation 使用备忘2
title: Annotation 使用备忘 date: 2018-01-02 20:48:43 tags: [Annotation] categories: [Programming,Java] - ...
- groupadd命令详解
基础命令学习目录首页 原文链接:https://wtj6891.iteye.com/blog/2096076 groupadd创建组群 使用groupadd命令可以在系统中创建组群账户 语法: gro ...
- Python20 - Day09
python并发编程之多线程理论 1.什么是线程? 进程只是用来把资源集中到一起(进程是一个资源单位,或者说资源集合),而线程才是cpu上的执行单位. 多线程(多个控制线程)的概念是,在一个进程中存在 ...
- FFmpeg简单转码程序--视频剪辑
学习了雷神的文章,慕斯人分享精神,感其英年而逝,不胜唏嘘.他有分享一个转码程序<最简单的基于FFMPEG的转码程序>其中使用了filter(参考了ffmpeg.c中的流程),他曾说想再编写 ...
- web05-CounterServlet
电影网站:www.aikan66.com 项目网站:www.aikan66.com 游戏网站:www.aikan66.com 图片网站:www.aikan66.com 书籍网站:www.aikan66 ...
- 除了C语言,C++······竟然还有Z语言?
只能说自己见识短,头一次听说Z语言.先普及一下吧: Z语言是由牛津大学程序设计研究小组开发的一种形式语言,它是一种以一阶谓词演算为主要理论基础的规约语言,是一种功能性语言.Z语言是将事物的状态和行为用 ...
- vs2013+python+ cocos2d-x-3.3rc0环境搭建
1.vs2013安装一路next,安装即可,时间1~2个小时 2.解压cocos2d-x-3.3rc0 build文件夹里会有名为 cocos2d-win32.vc2012的sln文件 打开 ...
- 谈对“Git”的认识与理解
自诞生于2005年以来,Git日臻完善,在高度易用的同时,仍然保留着初期设定的目标.它的速度飞快,及其适合管理大项目,它还有着令人难以置信的非线性分支管理系统,可以应付各种复杂的项目开发需求.接着说说 ...