您的位置:首页 > 其它

【ACM】hdu_2007_平方和与立方和_201307261533

2013-07-26 15:58 190 查看
平方和与立方和
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 69792 Accepted Submission(s): 21706

Problem Description
给定一段连续的整数,求出他们中所有偶数的平方和以及所有奇数的立方和。

Input
输入数据包含多组测试实例,每组测试实例包含一行,由两个整数m和n组成。

Output
对于每组输入数据,输出一行,应包括两个整数x和y,分别表示该段连续的整数中所有偶数的平方和以及所有奇数的立方和。
你可以认为32位整数足以保存结果。

Sample Input
1 3
2 5

Sample Output
4 28
20 152

#include <stdio.h>
int main()
{int m,n;
while(scanf("%d %d",&m,&n)!=EOF)
{
int i,a,b,t;
a=b=0;
if(m>n)
{t=m;m=n;n=t;}
if(m%2==0)
{for(i=m;i<=n;i+=2)
a+=i*i;
for(i=m+1;i<=n;i+=2)
b+=i*i*i;
}
else
{for(i=m;i<=n;i+=2)
b+=i*i*i;
for(i=m+1;i<=n;i+=2)
a+=i*i;
}
printf("%d %d\n",a,b);
}
return 0;
}
/*错误原因:没有考虑从大到小,只考虑的从小到大*/

#include <stdio.h>
int main()
{int m,n;
while(scanf("%d %d",&m,&n)!=EOF)
{
int i,a,b,t;
a=b=0;
if(m>n)
{t=m;m=n;n=t;}
if(m%2==0)
{for(i=m;i<=n;i+=2)
a+=i*i;
for(i=m+1;i<=n;i+=2)
b+=i*i*i;
}
else
{for(i=m;i<=n;i+=2)
b+=i*i*i;
for(i=m+1;i<=n;i+=2)
a+=i*i;
}
printf("%d %d\n",a,b);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: