USACO 1.4 Arithmetic Progressions (等差数列)
来源:互联网 发布:网络综合布线施工要求 编辑:程序博客网 时间:2024/05/20 22:40
【USACO1.4.3】Arithmetic Progressions 等差数列
Time Limit:50000MS Memory Limit:65536K
Total Submit:47 Accepted:23
Case Time Limit:5000MS
Description
一个等差数列是一个能表示成a, a+b, a+2b,..., a+nb (n=0,1,2,3,...)的数列。
在这个问题中a是一个非负的整数,b是正整数。写一个程序来找出在双平方数集合(双平方数集合是所有能表示成p的平方 + q的平方的数的集合)S中长度为n的等差数列。
Input
第一行: N(3<= N<=25),要找的等差数列的长度。
第二行: M(1<= M<=250),搜索双平方数的上界0 <= p,q <= M。
Output
如果没有找到数列,输出`NONE'。
如果找到了,输出一行或多行, 每行由二个整数组成:a,b。
这些行应该先按b排序再按a排序。
所求的等差数列将不会多于10,000个。
Sample Input
57
Sample Output
1 437 42 829 81 125 1213 1217 125 202 24
解题思路:
这题让我收获很大,,,其实一读后,就知道是一个枚举的题,但是我想了快半小时。。。。然后打完还T了,最后,看了展华的空间,,有个地方我没处理好,改了后就A过了,,我记着某个点的数据竟然达到了4.4S,....还是太弱了,必须要强起来。
先说说题目吧,其实就是给你说了一个数列的长度和一个上界,然后呢,你只需要把p*p+q*q的所有元素枚举出来,放在a数组里面。。。接下来,就开始枚举首项和公差了,算出limit = 2* m*m = 2*250*250 = 125000 后,我们枚举的范围就大体被确定下来了。
公差的范围:i = 1->limit/(n-1);
首项的范围:j = 0->j+(n-1)*i<=limit;
代码:
/* ID:wikioi_2 PROG: ariprog LANG: C++ */# include<cstdio># include<iostream>using namespace std;# define MAX 125000+4int a[MAX];int main(void){ int n,m; freopen("ariprog.in","r",stdin); freopen("ariprog.out","w",stdout); cin>>n>>m; for ( int p = 0;p <= m;p++ ) { for ( int q = 0;q <= m;q++ ) { a[q*q+p*p] = 1; } } int flag = 0; int limit = 2*m*m; int i,j; for ( i = 1;i <= limit/(n-1);i++ ) { for ( j = 0;j+(n-1)*i<= limit;j++ ) { int cnt = 0; for ( int temp = j;temp <= limit;temp+=i ) { if ( a[temp] == 1 ) { cnt++; } else { break; } if ( cnt==n ) { break; } } if( cnt==n ) { flag = 1; cout<<j<<" "<<i<<endl; } } } if ( flag==0 ) { cout<<"NONE"<<endl; } return 0;}
- USACO 1.4 Arithmetic Progressions (等差数列)
- 【USACO题库】1.4.3 Arithmetic Progressions等差数列(模拟)
- Usaco 1.4.3 等差数列(Arithmetic Progressions)
- USACO:1.4.3 Arithmetic Progressions 等差数列 解析
- 1251. 【USACO题库】1.4.3 Arithmetic Progressions等差数列
- USACO 1.4-Arithmetic Progressions
- [usaco]1.4 Arithmetic Progressions
- usaco 1.4 Arithmetic Progressions
- USACO 1.4 Arithmetic Progressions
- USACO 1.4 Arithmetic Progressions
- USACO 1.4-Arithmetic Progressions
- USACO 1.4 Arithmetic Progressions
- USACO Section 1.4 - Arithmetic Progressions (暴力)
- USACO-Section 1.4 Arithmetic Progressions(枚举)
- USACO 1.4.4 Arithmetic Progressions
- [USACO 1.4.3] Arithmetic Progressions
- usaco 1.4.4 Arithmetic Progressions
- USACO 1.4.4 Arithmetic Progressions
- MarkDown中一键贴图 for Mac
- 把相同的精灵装上车——使用CCSpriteBatchNode优化
- Observer观察者模式
- 技术揭秘12306改造(一):建立可伸缩扩展的云应用平台
- codeforces 268D Wall Bars (dp)
- USACO 1.4 Arithmetic Progressions (等差数列)
- Nginx+keepalive实现高可用热备负载均衡
- Android View创建和销毁调用的所有方法
- GIT 快速操作手册
- POI的简单用例
- 黑马程序员——Sql知识总结
- WCF之契约的分类
- 【Android Wear】
- LAMP一键卸载