[水题]HDOJ2000~2010

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.0010.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 )
之前这么写,也出现了问题,时间超时,再次说明,在写输入的时候,由于数值是系统提供,会在范围内,所以不必自己再加上判断的条件
*/
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值