2016HUAS_ACM暑假集训1A - 士兵队列训练问题

这道题我觉得是个简单的模拟题,整理一下思路,弄清楚题意就好了。

新手上路,采用两个数组进行交互赋值,用的方法也比较笨,思路差不多都在代码的注释里了。

下面是题目大意:

首先将士兵从1开始编号(士兵总数不超过5000),然后开始1 2 1 2...报数,报到2的士兵出列,剩下的向小序号方向靠拢,然后按照1 2 3 1 2 3... 报数,报到3的出列。以此类推(1 2 1 2...报数后再1 2 3 1 2 3...报数),直到剩下的士兵人数不超过3人,并且输出他们原来的编号。

格式要求如下:

第一行表示的是一个测试组数N,下面N行是每个案例士兵人数。

Sample Input

2

20

40

Sample Output

1 7 19

1 19 37

 1 #include<iostream>
 2 #include<string.h>
 3 using namespace std;
 4
 5 int n,N,i,j,a[5001],b[5001],c;//我一般比较喜欢定义为全局变量
 6
 7 int main()
 8 {
 9     cin >> N;
10     while(N--)
11     {
12         memset(a,0,sizeof(a));//初始化一下两个要用到的数组
13         memset(b,0,sizeof(b));
14         cin >> n;
15         for(i=1;i<=n;i++)
16             a[i]=i;//为n个新兵进行编号
17         while(n>3)//人数大于3的时候执行循环内的语句
18         {
19             for(i=1,j=1;i<=n;i++)
20             {
21                 if(i%2!=0)//1 2 1 2...报数导致a数组下标为偶数的全报的2,应当剔除
22                 {
23                     b[j]=a[i];//把a数组内下标为奇数的数放到b数组内
24                     j++;
25                 }
26             }
27             c=j-1;//j在执行完最后一个赋值后,又执行了一次j++,所以留下的士兵应该为j-1
28             if(c<4)//如果满足条件,直接输出,结束此次循环
29             {
30                 for(i=1;i<c;i++)
31                     cout<<b[i]<<‘ ‘;
32                 cout<<b[c]<<endl;
33                 break;
34             }
35             for(j=1,i=1;j<=c;j++)//1 2 3 1 2 3...报数
36             {
37                 if(j%3!=0)
38                 {
39                     a[i]=b[j];//把b数组内下标为3的倍数的数放到a数组内
40                     i++;
41                 }
42             }
43             n=i-1;//同上面的c=j-1;
44         }
45         if(n<4)
46         {
47             for(i=1;i<n;i++)
48                 cout<<a[i]<<‘ ‘;
49             cout<<a[n]<<endl;
50         }
51     }
52     return 0;
53 }

时间: 2024-12-19 09:50:36

2016HUAS_ACM暑假集训1A - 士兵队列训练问题的相关文章

2016HUAS_ACM暑假集训2L - Points on Cycle(圆上的点)

一个简单的几何题,自己在纸上列出方程解出结果的表达式,再用程序表达出来就行了. 大致题意:一个圆心在原点的圆,半径未知,现在给你圆上的一点,让你在这个圆上找到另外两点,使得这三点构成的三角形的周长最长. 样例输入:(第一行为一个整数N,表示后面有N组案例,每个案例给出一组圆上点的坐标) 2 1.500        2.000 563.585    1.251 样例输出:(其他两个点的坐标) 0.982 -2.299 -2.482 0.299 -280.709  -488.704  -282.8

2016HUAS_ACM暑假集训3G - 还是畅通工程

最小生成树,题目简单.套的Prim模板,其他的题目比较有意义. Sample Input 3                             //村庄个数1 2 1                       //连通情况及权值1 3 22 3 441 2 11 3 41 4 12 3 32 4 23 4 50 Sample Output       //输出最小生成树的权 3 5 1 #include<stdio.h> 2 #include<string.h> 3 #de

2016HUAS_ACM暑假集训4A - 递推

利用组合公式C(n,m)=C(n-1,m)+C(n-1,m-1).也就是从n个数里面选择m个数.按递增方式放在每一层循环. 杨辉三角+二项式定理,还真是挺有“意思”的一道题.说实话,非原创.见谅..... 题目大意:一个循环结构有m层,第一层是1~n,以后每加一层,循环变量的初值都都在上一层的基础上加1. 例如:第一层是1~n,那么第二层就是2~n,以此类推.求出m层的循环次数(答案对1007取模). Sample Input 2                                

2016HUAS_ACM暑假集训4C - 递推

题目大意:给你一个高为n ,宽为m列的网格,计算出这个网格中有多少个矩形. 这里我们可以这样看: 对于行:假如是m单位长度,则长度为1的矩形有m个,长度为2的矩形有m-1个......长度为m的只有1个,所以总共的矩形是1+2+...+m=(1+m)*m/2个 对于列:同行可以. 所以,总的矩形数=行*列.得出通项公式N(m,n) =  (1+m)*(1+n)*m*n/4. #include<iostream> using namespace std; int t,n,m; int main(

2016HUAS_ACM暑假集训4D - 计数,排列

一个错排公式的基础应用. 大致题意:求n个数的错误排列方式.(每个都要错) 在这里先贴一下错排公式:D(1)=0:D(2)=1:D(n)=(n-1)*(D(n-1)+D(n-2)) 它的推导也非常有意思,用的应该是递归的思想吧(个人猜测). Sample Input 2 3 Sample Output 1 2 这题注意两点: 1.长整型__int64或者long long 2.最好打一下表,防止超时 然后,然后就过了呗...... #include<iostream> #include<

2016HUAS_ACM暑假集训2E - I Hate It

又是一个线段树的应用,不过跟上一题(D-排兵布阵)不同的是,这次是求某段区间上的最值,而不是某段区间和.当然,数据更新是必须的.D题注释已经很详细了,所以这题注释少点. 大致题意:给你N个已经排好的学生成绩,然后有M条指令,输出对应指令的结果.指令有两种: 1.Q  i  j:询问i到j的最值 2.U  i  j:把学生编号为i的成绩改为j 输入输出格式: Sample Input 5     6                    //第一行两个整数N,M,表示N个学生和M条指令( 0<N<

2016HUAS_ACM暑假集训4K - 基础DP

我不知道怎么用DP,不过DFS挺好用.DFS思路很明显,搜索.记录,如果刚好找到总价值的一半就说明搜索成功. 题目大意:每组6个数,分别表示价值1到6的物品个数.现在问你能不能根据价值均分. Sample Input                                  //6种价值物品的个数,全为0时结束 1 0 1 2 0 0 1 0 0 0 1 1 0 0 0 0 0 0 Sample Output                              //注意格式,空两行

2016HUAS_ACM暑假集训4M - 基础DP

简单的0-1背包问题,大家都会做的.题意不想解释太多. 简述题目的案例及以几个关键 Sample Input 1                            //测试组数T 5 10                       //骨头总个数N,背包总体积V 1 2 3 4 5                //N块骨头各自的价值 5 4 3 2 1                //N块骨头各自的体积 Sample Output        //输出最大价值 14 注意:每种骨头只

2016HUAS_ACM暑假集训2B - The Suspects(感染者)

并查集初步应用,还不是很熟练.并查集两个主要函数:Union和Find.Union通常把两条不连通的支路使其连通:Find用来查找根节点,必要的要进行路径压缩. 大致题意:0号学生是默认的感染者,在M组团体中,如果出现了0号,则整个团体都是感染者. 样例: Sample Input 100 4                        //第一行两个整数N,M,表示N个学生(已编号0~N-1),M个团体  (0 < N <= 30000,0 <= M <= 500) 2 1 2