codeforces A. Xenia and Divisors 解题报告
题目链接:http://codeforces.com/problemset/problem/342/A
题目意思:给出n个数,找出n/3个组且每组有3个数,这三个数必须要符合两个条件:1、a < b < c;2、b mod a = 0 和 c mod b =0。如果找不到,输出-1。
其实每组内只可能是这三组数的其中一组:1 2 4; 1 2 6; 1 3 6
以下注释部分读者可以直接忽略。
/*
刚开始想得很复杂,三个数组分别存储初始数s,记录已输出的数 vis 还有经判断符合条件将要输出的数a。sort从小到大排序,每组数里面的三个数的范围分别是0~n/3,n/3~2n/3和2n/3~n。可想而知,TLE!!!
后来再想,得出每组数的第一个数绝对是1且和n的个数是相等的,输入序列中只要存在5或者7,就绝对是不符合条件的。2、4、6的个数如何确定?本来有种很笨的方法,就是输入的同时统计1、2、4、6的个数,存到c1、c2、c4和c6中,每输出一个就在相应的ci(i=1、2、4 or 6)减1。但是如果不符合如何回溯???总之就是简单问题复杂化了。不堪入目啊!!!
*/
此题分类竟然是属于贪心和模拟,个人觉得像是数学题。
这里的统计1、2、4、6的个数是对数组下标的灵活运用,temp暂时保存输入的数,则s[temp]即可以实现所保存数的个数统计。
至于如何知道1 2 4、 1 2 6 和 1 3 6各有多少个?真心觉得是考个人的观察能力= =!1的总个数 = 2 和 3的总个数,额~~还是拿符号来讲。即 s[1] = s[2] + s[3],另外还有s[1] = s[4] + s[6],最后一条,十分值得注意:s[2] >= s[4],否则对于类似1 3 4 的数据是过不了的!!!!
#include <iostream>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
using namespace std; const int maxn = + ;
int s[maxn]; int main()
{
int n, i, flag, temp;
while (scanf("%d", &n) != EOF)
{
flag = ;
memset(s, , sizeof(s)); // 每一轮一定要记得清零
for (i = ; i < n; i++)
{
scanf("%d", &temp);
s[temp]++; // 数组下标灵活运用
if (temp == || temp == )
flag = ; // 一旦有5和7,就绝对不符合条件了
}
if (flag && s[] == s[] + s[] && s[] == s[] + s[] && s[] >= s[])
{
for (i = ; i < s[]; i++) // 每组数的个数,聪明的读者慢慢体会
printf("1 2 4\n");
for (i = ; i < s[] - s[]; i++)
printf("1 2 6\n");
for (i = ; i < s[]; i++)
printf("1 3 6\n");
}
else
printf("-1\n");
}
return ;
}
codeforces A. Xenia and Divisors 解题报告的更多相关文章
- codeforces B. Xenia and Ringroad 解题报告
题目链接:http://codeforces.com/problemset/problem/339/B 题目理解不难,这句是解题的关键 In order to complete the i-th ta ...
- codeforces B. Xenia and Spies 解题报告
题目链接:http://codeforces.com/problemset/problem/342/B 题目意思:有n个spy,编号从1-n,从左到右排列.现在的任务是,spy s要把信息传递到spy ...
- Codeforces Educational Round 92 赛后解题报告(A-G)
Codeforces Educational Round 92 赛后解题报告 惨 huayucaiji 惨 A. LCM Problem 赛前:A题嘛,总归简单的咯 赛后:A题这种**题居然想了20m ...
- codeforces 476C.Dreamoon and Sums 解题报告
题目链接:http://codeforces.com/problemset/problem/476/C 题目意思:给出两个数:a 和 b,要求算出 (x/b) / (x%b) == k,其中 k 的取 ...
- Codeforces Round #382 (Div. 2) 解题报告
CF一如既往在深夜举行,我也一如既往在周三上午的C++课上进行了virtual participation.这次div2的题目除了E题都水的一塌糊涂,参赛时的E题最后也没有几个参赛者AC,排名又成为了 ...
- codeforces 507B. Amr and Pins 解题报告
题目链接:http://codeforces.com/problemset/problem/507/B 题目意思:给出圆的半径,以及圆心坐标和最终圆心要到达的坐标位置.问最少步数是多少.移动见下图.( ...
- codeforces 500B.New Year Permutation 解题报告
题目链接:http://codeforces.com/problemset/problem/500/B 题目意思:给出一个含有 n 个数的排列:p1, p2, ..., pn-1, pn.紧接着是一个 ...
- codeforces 462C Appleman and Toastman 解题报告
题目链接:http://codeforces.com/problemset/problem/461/A 题目意思:给出一群由 n 个数组成的集合你,依次循环执行两种操作: (1)每次Toastman得 ...
- codeforces 460A Vasya and Socks 解题报告
题目链接:http://codeforces.com/problemset/problem/460/A 题目意思:有一个人有 n 对袜子,每天早上会穿一对,然后当天的晚上就会扔掉,不过他会在 m 的倍 ...
随机推荐
- python学习笔记4(对象/引用;多范式; 上下文管理器)
### Python的强大很大一部分原因在于,它提供有很多已经写好的,可以现成用的对象 21. 动态类型:对象/引用 对象和引用: 对象是储存在内存中的实体,对象名只是指向这一对象的引用(refere ...
- 7.Android之评分条RatingBar和拖动条SeekBar学习
评分条RatingBar和拖动条SeekBar很常见,今天来学习下. (1)RatingBar评分条 如图: <RelativeLayout xmlns:android="http:/ ...
- POJ 1466 Girls and Boys
Girls and Boys Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://poj.org/problem?id=1466 Descripti ...
- groovy-位运算
从Groovy 1.0 beta 10开始,Groovy支持位运算:<<. >>, >>>, |, &, ^, and ~. 下表列出了位运算的操作符 ...
- data URI
参考资料:http://www.cnblogs.com/hustskyking/p/data-uri.html 与http,ftp等协议类似,data URL也是一种协议,不同的是它直接将数据(编码或 ...
- 使用.NET FrameWork获取CPU,内存使用率以及磁盘空间
在以前,我们想获取CPU,内存等信息就不得不借助win32 API来实现.但现在,.NET FrameWork已经把这些API封装到.NET类库中了,所以我们可以借助.NET类库很轻松的获取这些信息. ...
- hdu 2047 阿牛的EOF牛肉串
如果末尾加的是E或F,显然是2*a[i-1] 如果末尾加的是O,则末2位一定是EO或FO,则为2*a[i-2]. 然后两者相加 2*a[i-1]+2*a[i-2] = 2*(a[i-1]+a[i-2] ...
- https://github.com/yrs244742688/GeneratePemWithMoAndEx RSA加密
<RSAKeyValue> <Modulus> xA7SEU+e0yQH5rm9kbCDN9o3aPIo7HbP7tX6WOocLZAtNfyxSZDU16ksL6 Wjuba ...
- mono 3.4.0 make install的时候出现"找不到 Microsoft.Portable.Common.targets 文件”的错误提示解决方法
如果在这时就进行配置安装Mono的话,会在make阶段得到一个“找不到 Microsoft.Portable.Common.targets 文件”的错误提示, 所以需要先进行如下处理: #> c ...
- [实战]MVC5+EF6+MySql企业网盘实战(27)——应用列表
写在前面 本篇文章将实现应用列表,同样和其他列表的不同之处,在于查询条件的不同. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘 ...