题目链接:http://codeforces.com/problemset/problem/352/B

题目意思:给出一个长度为n的序列   a1, a2, ..., an(序号i,1 <= i <= n)。需要从这个序列中,找出符合这两个条件的数:1、这个数在序列 a1, a2, ..., an 中; 2、该数的所有位置(也就是序号i)构成等差数列。一旦有一个位置不满足(此时和上一个位置所求出的公差就与之前的公差不相等),这个数就不符合条件,不应该输出。找完之后,输出所有满足这两个条件的数的总数,还有这些数以及对应的公差。

值得注意的地方有:当这个数在序列中只出现一次的时候,也属于可输出的,此时它的公差为0,也就是ST 1的情况; 还有,整个序列一个都找不到这样的数,要输出0。

这条是我赛中第一次提交的,因为一下子就看懂题目了。不过赛中是没过到啦,以为很简单...赛后,修改,调试,整整两天多,终于AC了。方法比较笨,还是那句话,自己写的特别有感觉。后来看了别人用vector来做,代码长度缩短了很多。看来还是需要学一下容器啊~~~

方法一:

    

Time Memory
92 ms 2000 KB
 #include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std; const int maxn = 1e5 + ; struct pairs
{
int index; // 保存位置的编号i
int num; // 保存序列的数,即题目中的a[i]
}p[maxn]; int cmp(pairs a, pairs b)
{
if (a.num != b.num)
return a.num < b.num;
return a.index < b.index; // 关键!!!保证公差是正数,否则过不了test 10
} int c[maxn], b[maxn];
int f[maxn]; int main()
{
int i, j, k, n, sum;
while (scanf("%d", &n) != EOF)
{
memset(c, , sizeof(c));
for (j = i = ; i <= n; i++)
{
scanf("%d", &p[i].num);
c[p[i].num]++; // 统计a[i]在序列中出现多少次
if (c[p[i].num] == )
{
b[j++] = p[i].num; // 保存a[i]
}
p[i].index = i;
}
k = j;
sort(p+, p+n+, cmp); // 序列a的数从小到大排序,如果相同,则按具体的位置从小到大排序
sort(b+, b+j); // 保证输出的序列是递增的
/* for (i = 1; i <= n; i++)
{
printf("p[%d].index = %d, p[%d].num = %d\n", i, p[i].index, i, p[i].num);
}
*/
memset(f, , sizeof(f)); // 保存公差
int tmp, j, flag, minus;
sum = ;
for (i = ; i <= n; i += c[p[i].num])
{
// printf("i = %d\n", i);
// printf("c[%d] = %d\n", p[i].num, c[p[i].num]);
if (c[p[i].num] == ) // 在序列中只出现一次的数,公差设为0
{
f[p[i].num] = ;
sum++; // 也属于可输出的
}
else
{
flag = ;
for (j = i; j < c[p[i].num]+i-; j++) // 检测相同数字的公差是否相等
{
// printf("j = %d\n", j);
if (j == i) // 用第一、二个的位置算出公差即可,下面用这个公差来检查其他位置的公差是否和这个公差相等
{
tmp = p[j+].index - p[j].index;
// printf("tmp = %d\n", tmp);
}
minus = p[j+].index - p[j].index;
// printf("minus = %d\n\n", minus);
if (tmp != minus)
{
f[p[i].num] = -; // 发现有一个位置不等于之前算出的公差
flag = ;
// printf("error !!!!\n\n"); }
}
if (j == c[p[i].num]+i- && !flag) // 相同的数的所有位置算出的公差都相等
{
sum++;
// printf("success!!!\n");
f[p[i].num] = tmp; // 保存公差
}
}
}
if (sum)
{
printf("%d\n", sum); // 符合条件的总数
for (i = ; i < k; i++)
{
if (f[b[i]] != -)
{
printf("%d %d\n", b[i], f[b[i]]);
}
}
}
else
printf("0\n");
}
return ;
}

方法二:

Time Memory
92 ms 4900 KB

用vector方法写的,记得每次都要清空。

 #include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <vector>
using namespace std; const int maxn = 1e5 + ;
const int maxm = ; vector <int> s[maxn];
int ans[maxn][maxm]; int main()
{
int i, j, n, tmp, flag;
while (scanf("%d", &n) != EOF)
{
memset(s, , sizeof(s));
for (i = ; i <= n; i++)
{
scanf("%d", &tmp);
s[tmp].push_back(i);
}
int d, len, cnt = ;
for (i = ; i <= maxn; i++)
{
flag = ;
len = s[i].size();
if (len == )
continue;
else if (len == )
{
ans[cnt][] = i;
ans[cnt][] = ;
cnt++;
}
else
{
d = s[i][] - s[i][];
if (len == )
{
ans[cnt][] = i;
ans[cnt][] = d;
flag = ;
cnt++;
}
// printf("d = %d\n", d);
if (!flag)
{
for (j = ; j < len; j++)
{
if (s[i][j] - s[i][j-] != d)
break;
}
if (j == len)
{
ans[cnt][] = i;
ans[cnt][] = d;
cnt++;
}
}
}
}
printf("%d\n", cnt);
for (i = ; i < cnt; i++)
{
printf("%d %d\n", ans[i][], ans[i][]);
}
}
return ;
}

codeforces B. Jeff and Periods 解题报告的更多相关文章

  1. codeforces A. Jeff and Digits 解题报告

    题目链接:http://codeforces.com/problemset/problem/352/A 题目意思:给定一个只有0或5组成的序列,你要重新编排这个序列(当然你可以不取尽这些数字),使得这 ...

  2. Codeforces Educational Round 92 赛后解题报告(A-G)

    Codeforces Educational Round 92 赛后解题报告 惨 huayucaiji 惨 A. LCM Problem 赛前:A题嘛,总归简单的咯 赛后:A题这种**题居然想了20m ...

  3. codeforces 476C.Dreamoon and Sums 解题报告

    题目链接:http://codeforces.com/problemset/problem/476/C 题目意思:给出两个数:a 和 b,要求算出 (x/b) / (x%b) == k,其中 k 的取 ...

  4. Codeforces Round #382 (Div. 2) 解题报告

    CF一如既往在深夜举行,我也一如既往在周三上午的C++课上进行了virtual participation.这次div2的题目除了E题都水的一塌糊涂,参赛时的E题最后也没有几个参赛者AC,排名又成为了 ...

  5. Codeforces 352B - Jeff and Periods

    352B - Jeff and Periods 思路:水题,考验实现(implementation)能力,来一波vector[允悲]. 代码: #include<bits/stdc++.h> ...

  6. codeforces 507B. Amr and Pins 解题报告

    题目链接:http://codeforces.com/problemset/problem/507/B 题目意思:给出圆的半径,以及圆心坐标和最终圆心要到达的坐标位置.问最少步数是多少.移动见下图.( ...

  7. codeforces 500B.New Year Permutation 解题报告

    题目链接:http://codeforces.com/problemset/problem/500/B 题目意思:给出一个含有 n 个数的排列:p1, p2, ..., pn-1, pn.紧接着是一个 ...

  8. codeforces B. Xenia and Ringroad 解题报告

    题目链接:http://codeforces.com/problemset/problem/339/B 题目理解不难,这句是解题的关键 In order to complete the i-th ta ...

  9. codeforces 462C Appleman and Toastman 解题报告

    题目链接:http://codeforces.com/problemset/problem/461/A 题目意思:给出一群由 n 个数组成的集合你,依次循环执行两种操作: (1)每次Toastman得 ...

随机推荐

  1. RIP、OSPF、BGP、动态路由选路协议、自治域AS

    相关学习资料 tcp-ip详解卷1:协议.pdf http://www.rfc-editor.org/rfc/rfc1058.txt http://www.rfc-editor.org/rfc/rfc ...

  2. 安装python爬虫scrapy踩过的那些坑和编程外的思考

    这些天应朋友的要求抓取某个论坛帖子的信息,网上搜索了一下开源的爬虫资料,看了许多对于开源爬虫的比较发现开源爬虫scrapy比较好用.但是以前一直用的java和php,对python不熟悉,于是花一天时 ...

  3. mvc中EditorFor TextBoxFor什么区别

    EditorFor 是映射到Model 属性上面,忽略用户自定义属性和样式 Model 可以为nullTextBoxFor是映射到Model 属性上面,可以用户自定义属性和样式 Model 不可以为n ...

  4. 异步httpCilent框架post提交到服务器

    1 导入AsyncHttPclient框架包下的类: 2在主方法写上这代码即可实现post请求:

  5. hibernate提供的5种检索数据方式

    一.五种检索数据方式 1.OID检索,即使用session.get或session.load通过类及指定id查询数据,如Customer c=(Customer)session.get("C ...

  6. JavaScript模块化学习基础

    http://www.ruanyifeng.com/blog/2012/10/javascript_module.html 一.原始写法 模块就是实现特定功能的一组方法. 不同函数简单放在一起就算一个 ...

  7. 我和NLP的故事(转载)

    正值ACL录用结果发布,国内的老师和同学们又是一次大丰收,在这里再次恭喜所有论文被录用的老师和同学们!我人品爆发,也收获了自己硕士阶段的第二篇ACL论文.本来只是想单纯分享下自己中论文的喜悦,但没成想 ...

  8. 如何有效的保护 JAVA 程序

    从头到尾保护 JAVA 目前关于 JAVA 程序的加密方式不外乎 JAVA 模糊处理(Obfuscator)和运用 ClassLoader 方法进行加密处理这两种方式(其他的方式亦有,但大多是这两种的 ...

  9. 基于HttpListener的web服务器

    写在前面 前面两篇文章分别介绍了基于原始socket的web服务器和基于tcpListener的web服务器,本篇文章将继续介绍另外一种基于HttpListener的. HttpListener Ht ...

  10. linux下ping的C语言实现(转)

    #include <stdio.h> #include <signal.h> #include <arpa/inet.h> #include <sys/typ ...