ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0

HDOJ HDU 2058 The sum problem ACM 2058 IN HDU

Posted on 2010-08-04 22:18 MiYu 阅读(845) 评论(2)  编辑 收藏 引用 所属分类: C/C++ACM ( 数论 )
//MiYu原创, 转帖请注明 : 转载自 ______________白白の屋

题目地址 :
         http://acm.hdu.edu.cn/showproblem.php?pid=2058

观察a+1,a+2…a+d
全部相加等于M
即(a+1+a+d)*d/2 = M,
这里d是平方,我们可以从长度d入手,这样就能把范围由M转换成M^1/2 ;

这里把代码中的①和②解释下:
①:当a+1,a+2…a+3相加等于M时,即
(a+1+a+d)*d/2 = M
而a最小是0,所以(d+1)*d/2=M时d去最大值,就是这步把时间复杂度减小的。
d就是sqrt(2*M)

②:(a+1+a+d)*d/2 = M
所以a*d + (d+1)/2 = M
所以要使等式成立,M-(d+1)/2必须是d的倍数。
此为奋斗哥的代码 :    0rz........下

//MiYu原创, 转帖请注明 : 转载自 ______________白白の屋

#include 
<iostream>
#include 
<cmath>
#include 
<algorithm>
using namespace std;
int N, M;
int main()
{
    
int flag = 0;
    
while(scanf("%d %d"&N, &M) && (M||N))
    {
        
int i;
        
int len = int(sqrt(M*2.0));  // ①
        for(i=len; i>=1--i)
        {
            
int temp = M-(i*i+i)/2;   // ②
            if(temp%== 0)
                printf(
"[%d,%d]\n", temp/i+1, temp/i+i);
        }
        printf(
"\n");
    }
    
return 0;
}

Feedback

# re: HDOJ HDU 2058 The sum problem ACM 2058 IN HDU   回复  更多评论   

2010-08-07 21:23 by 0617xuan
先顶下。。。似乎还没看懂。。。等会仔细的看。。。

# re: HDOJ HDU 2058 The sum problem ACM 2058 IN HDU   回复  更多评论   

2010-08-07 22:28 by Tanky Woo
Orz第二种方法

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理