首页 > 代码库 > 零基础(伪)HDOJ水题总结【1】

零基础(伪)HDOJ水题总结【1】

首先要解决的是输入输出的问题。作为一个渣渣新手,我用以前学的 C++写了错误代码提交,后果可想而知。

所以认认真真的看了【ACM新手之八大输入输出】,格式记好,在后面运用会越用越熟的。
2000
很easy的一题,首先,现在假设我什么都不会(至少编译器,头文件,基本格式知道)我要解决该怎么办?(以后需要学的和缺少的直接补上,不多说。)
1.比较大小,高中算法讲过。三个数的轮序比较。至于排序算法。我搜到的【冒泡排序】以后再探讨。
2.但是getchar()的用法,忘了。我只知道用一个东西(…)把字符转化成ASCII码,然后可以排序。

关于ASCII:

A65 - Y91

048 - 957

 另:getchar()  putchar()  puts()

puts()是用来输出字符串并换行 
putchar()是输出字符变量

getchar() 永远只向缓存中输入一个字符

puts(char *p)

printf(char *p,s)

审题:空格!

#include<stdio.h>int main(){    char ch1,ch2,ch3,temp;    while(scanf("%c%c%c",&ch1,&ch2,&ch3)!=EOF)    {        getchar();        if(ch1>ch2)        {          temp=ch1;          ch1=ch2;          ch2=temp;        }         if(ch1>ch3)        {            temp=ch1;            ch1=ch3;            ch3=temp;        }        if(ch2>ch3)        {            temp=ch2;            ch2=ch3;            ch3=temp;        }        printf("%c%2c%2c\n",ch1,ch2,ch3);    }return 0;}

2001
1.第二题竟然狗血的想到了数组(其实没那么麻烦,两个变量罢了)学呗,数组此题的代码不是一般的长啊。本着KISS原则(keep it simple and stupid)。还是用简单方法吧。【数组】

(定义一个二维数组Dist[2][10],假设有两点a(2,3),b(5,6),将他们的坐标放入数组中

Dist[0][0]=2;

Dist[0][1]=5;

Dist[1][0]=3;

Dist[1][1]=6;

他们间的距离就是double x=(Dist[0][0]-Dist[0][1])*(Dist[0][0]-Dist[0][1])+(Dist[1][0]-Dist[1][1])*(Dist[1][0]-Dist[1][1]);
double distance = Math.sqrt(x);)

神烦……


2.<math.h>与<cmath>
sqrt 和 abs fabs比较常用?库函数使用得当可以提高编码效率。

#include<stdio.h>#include<math.h>int main(){    double x1,y1,x2,y2,dist;    while(scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2)!=EOF)    {        dist=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));        printf("%.2lf\n",dist);    }    return 0;}

2002
1.#define 宏定义,方便以后的修改。
2.(刚搞懂C语言中没乘方:BASIC是有的。)

#include <math.h>double  y=pow(m,n);

 

#define PI 3.1415927#include<stdio.h>int main(){    double a,v;    while(scanf("%lf",&a)!=EOF)    {        v=(4.0/3)*PI*a*a*a;        printf("%.3lf\n",v);    }    return 0;}

2003

1.与其用函数,不如直接来的爽快。

2.double

#include<stdio.h>          int main(){    double a;    while(scanf("%lf",&a)!=EOF)    {        if(a<0) a=(-a);        printf("%.2lf\n",a);    }return 0;}

 

2004

1.switch语句  学习 注意break

#include<stdio.h> int main(){    int a,b;    while(scanf("%d",&a)!=EOF)    {        b=a/10;        if(a<0||a>100)            b=(-1);        switch(b)        {        case 10:        case 9: printf("A\n");break;        case 8: printf("B\n");break;        case 7: printf("C\n");break;        case 6: printf("D\n");break;        case 5:        case 4:        case 3:        case 2:        case 1:        case 0: printf("E\n");break;        case -1:printf("Score is error!\n");break;        default:break;        }    }return 0;}

default:注意

2.但是 冗长剪枝。这是和下一题是一个道理。于是,看的【数组】就用上了。

#include <stdio.h>char r[11]={E,E,E,E,E,E,D,C,B,A,A};int main(){    int s;    while (scanf("%d",&s)!=EOF)        {        if(s>100||s<0)            printf("Score is error!\n");        else            printf("%c\n",r[s/10]);    }    return 0;}

2005

1.直接贴代码,如上

#include <stdio.h>int Month[2][13]={    {0,31,28,31,30,31,30,31,31,30,31,30,31},    {0,31,29,31,30,31,30,31,31,30,31,30,31}};int main(){    int y,m,d,sum,f,i;    while (scanf("%d/%d/%d",&y,&m,&d)!=EOF)        {        sum=0;        f=((y%400==0) || (y%100!=0) && (y%4==0));        i=1;        while (i<m)                sum+=Month[f][i++];        printf("%d\n",sum+d);    }    return 0;}

运算符:

==  比较运算符,即等于

=     赋值运算符,i=2即 2放入i中

   复合运算符  ,a+=b 其实就是a=a+b

 

2006

1.

#include<stdio.h>int main(){    int n,a,sum,i;    while(scanf("%d",&n)!=EOF)    {        sum=1;        for(i=0;i<n;i++)        {            scanf("%d",&a);            if(a%2!=0)            sum=sum*a;        }        printf("%d\n",sum);    }    return 0;}

2007

1.有没有发现读题的重要性……m、n比较大小坑了很多人呐。

#include<stdio.h>int main(){ int m,n,t; long x,y; while((scanf("%d%d",&m,&n))!=EOF) {  if(m>n){t=m;m=n;n=t;}
for(x=0,y=0;m<=n;m++) if(m%2!=0) y+=m*m*m; else x+=m*m; printf("%d %d\n",x,y); } return 0;}

2.

2010

#include<stdio.h>int main(){    int m,n,a,b,c,i,j,s,d[1000];    while(scanf("%d%d",&m,&n)!=EOF)    {        j=0;       for(i=m;i<=n;i++)        {            a=i/100;//取其百位数字            b=i/10-10*a;//取其十位数字            c=i%10;//取其个位数字            s=a*a*a+b*b*b+c*c*c;            if(s==i)            {d[j]=i;//判断三位数字的立方和是否等于本身,若等于

j++
;} 则将其存放到一数组中。 } if(j==0) printf("no\n"); else if(j==1) printf("%d\n",d[0]); else if(j>=2) { for(i=0;i<j-1;i++) printf("%d ",d[i]); printf("%d\n",d[j-1]); } }return 0;}

 

零基础(伪)HDOJ水题总结【1】