题解
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<stdlib.h>
#include<bits/stdc++.h>
using namespace std;
int main()
{
int m,n;
int a[10000];
int res1,res2;
while(scanf("%d%d",&m,&n)!=EOF){
if(m>n){
res1=0;
res2=0;
for(int i=n;i<=m;i++){
if(i%2==0)
res1=res1+pow(i,2);
else
res2=res2+pow(i,3)+0.5;
}
printf("%d %d\n",res1,res2);
}
else{
res1=0;
res2=0;
for(int i=m;i<=n;i++){
if(i%2==0)
res1=res1+pow(i,2);
else
res2=res2+pow(i,3)+0.5;
}
printf("%d %d\n",res1,res2);
}
}
return 0;
}
学习笔记
一开始WA,发现是没有处理m>n的情况,处理之后就好了。
注意点:pow函数的输出是浮点型的,所以pow(5,3)的时候输出了124,需要加上0.5来四舍五入。
math.h库里,pow函数是基于浮点运算的。
pow赋值给int的时候:
指数用常量,结果正确;
指数用int、double,结果错误
pow赋值给double的时候:
指数用常量、int、double,结果正确
!!所以在使用pow函数时,底数必须是常量(double型),结果才不会出现偏差。