2000ASCII码排序
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
char a, b, c, temp;
while(scanf("%c %c %c", &a, &b, &c) != EOF)
{
if(a > b)
{
temp = a;
a = b;
b = temp;
}
if(c < b)
{
temp = c;
c = b;
b = temp;
}
if(a > b)
{
temp = a;
a = b;
b = temp;
}
printf("%c %c %c\n", a, b, c);
getchar();
}
return 0;
}
//这题只要不是懒得写上面的if else差不多就对了
2001计算两点间的距离
#include <stdio.h>
#include <math.h>
int main()
{
double x1, y1, x2, y2;
while(scanf("%lf %lf %lf %lf", &x1, &y1, &x2, &y2) != EOF)
printf("%.2lf\n", sqrt((double)((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1))));
return 0;
}
/*之前出现了Output Limit Exceeded,原因是scanf中x1,x2,y1,y2位置错位,一定要小心细节*/
2002计算球体积
#include <stdio.h>
#define PI 3.1415927
double R;
int main()
{
while(scanf("%lf", &R) != EOF)
printf("%.3lf\n", 4.0/3*PI*R*R*R);
return 0;
}
/*之前WA了几次,用的是float,最后看别人的,改成double就AC了。。。赶紧去问了一下,float精度太低,经不住乱七八糟数据的考验,像0.001*0.001,0.001*0.001*0.001*999999*0.001这样的小数乘大数。。。基本都用double解决问题*/
2003球绝对值
#include <stdio.h>
int main()
{
double i;
while(scanf ("%lf",&i)!=EOF)
{
if (i<0)
printf ("%.2lf\n",i-i-i);
else
printf ("%.2lf\n",i);
}
return 0;
}
/*开始有点晕,,,不知道为什么,,,反正加个负号就行了,为什么要去搞个i-i-i这样的式子出来*/
#include <stdio.h>
int main(void)
{
double x;
while(scanf("%lf", &x) != EOF)
{
if(x > 0)
printf("%.2lf\n", x);
else
printf("%.2lf\n", -x);
}
return 0;
}
2004成绩转换
#include <stdio.h>
int main()
{
int i;
while (scanf("%d",&i)!=EOF)
{
if (i>=0&&i<=100)
switch(i/10)
{
case 0:
case 1:
case 2:
case 3:
case 4:
case 5:printf ("E\n");break;
case 6:printf ("D\n");break;
case 7:printf ("C\n");break;
case 8:printf ("B\n");break;
case 9:printf ("A\n");break;
case 10:printf ("A\n");break;
}
else
printf ("Score is error!\n");
}
return 0;
}
/*之前有次Presentation Error,是因为最后没有换行,,,注意细节啊*/
2005第几天?
#include <stdio.h>
int main()
{
int a[12]={31,28,31,30,31,30,31,31,30,31,30,31};
int b[12]={31,29,31,30,31,30,31,31,30,31,30,31};
int m,n,p;
int t=0;
int i,j;
while(scanf("%d/%d/%d",&m,&n,&p)!=EOF)
{
t=0;
if ((m % 4 == 0 && m % 100) || m % 400 == 0)
{
if (n==1)
printf ("%d\n",p);
else{
for (i=0;i<n-1;i++)
t=t+b[i];
t=t+p;
printf ("%d\n",t);}
}
else
{
if (n==1)
printf ("%d\n",p);
else{
for (i=0;i<n-1;i++)
t=t+a[i];
t=t+p;
printf ("%d\n",t);}
}
}
return 0;
}
/*之前WA了五次,一直搞不明白,特么的最后才知道是判断条件错了。。。。。我小学老师教我的用4除就好,搞的那么复杂干吗。。。。。也是醉*/
2006求奇数的乘积
#include <stdio.h>
int main()
{
int i,j,a[1000],t;
while (scanf("%d",&i)!=EOF)
{
t=1;
for (j=0;j<i;j++)
{
scanf ("%d",&a[j]);
if (a[j]%2!=0)
{
t=t*a[j];
}
}
printf ("%d\n",t);
}
}
2007平方和与立方和
#include <stdio.h>
int main()
{
int i,a,b,n,m,t;
while(scanf ("%d %d",&a,&b)!=EOF)
{
m=n=0;
if (a>b)
{
t=a;
a=b;
b=t;
}
for (i=a;i<=b;i++)
{
if (i%2==0)
{
m=m+i*i;
}
else
{
n=n+i*i*i;
}
}
printf("%d %d\n",m,n);
}
return 0;
}
/*之前WA一次,后来找到别人的代码看了下,发现错误在题目并没有直接说明最先输入的两个数字是按大小排序的,只是说是在这个范围内。。。。。算是我研究题目不够透彻吧,长个记性*/
2008数值统计
#include <stdio.h>
int main()
{
int i,j,m,n,p;
double a[100];
while(scanf("%d",&i)&i!=0)
{
m=n=p=0;
for (j=0;j<i;j++)
{
scanf("%lf",&a[j]);
if (a[j]>0)
m++;
else if (a[j]==0)
n++;
else
p++;
}
printf ("%d %d %d\n",p,n,m);
}
return 0;
}
2009求数列的和
#include <stdio.h>
#include <math.h>
int main()
{
int j,a;
double i,t=0;
while(scanf ("%lf",&i)!=EOF)
{
t=i;
scanf ("%d",&j);
for (a=0;a<j-1;a++)
{
t=t+sqrt(i);
i=sqrt(i);
}
printf ("%.2lf\n",t);
}
return 0;
}
/*最开始看到INPUT里面这么说:输入数据有多组,每组占一行,由两个整数n(n<10000)和m(m<1000)组成,n和m的含义如前所述。
我还特意在while里面加上条件,后来提交的时候又划了,发现AC了。。。说明在输入的时候不需要给出判断条件*/
2010水仙花数
/*之前出现三次Output Limit Exceeded,在网上查了一下才知道是最后多输出了一个空格,所以一直错*/
#include <stdio.h>
int main()
{
int m,n,i,g,s,b,temp=0;
while (scanf("%d %d",&m,&n)!=EOF)
{
temp=0;
for (i=m;i<=n;i++)
{
g=i%10%10;
s=i/10%10;
b=i/100;
if (i==g*g*g+s*s*s+b*b*b)
{
if (temp==0)
{
printf ("%d",i);
temp=1;
}
else
printf (" %d",i);
}
}
if (temp==1)
printf ("\n");
else
printf ("no\n");
}
return 0;
}
/*
while (scanf("%d %d",&m,&n) && m>=100 && m<=n && n<=999 )
之前这么写,也出现了问题,时间超时,再次说明,在写输入的时候,由于数值是系统提供,会在范围内,所以不必自己再加上判断的条件
*/