读入优化与输出优化

朴素读入优化与输出优化

【a+b问题】:读入两个数,输出两数之和。

/*
    Coded by Ice_teapoy
*/
#include 
#include 
//读入优化
int read()
{
    int res=0,f=1;
	char x=getchar();
    for (;!isdigit(x);x=getchar()) (x=='-')&&(f=-1);
    for (;isdigit(x);x=getchar()) res=(res<<3)+(res<<1)+(x^48);
    return f*res;
}
//输出优化
void write(int x)
{
    if (x<0) putchar('-'),x=-x;
    if (x>9) write(x/10);
    putchar(x%10+48);
}
int main()
{
	int a=read(),b=read();
	write(a+b);
}

fread、fwrite读入优化与输出优化

【a+b问题】:读入两个数,输出两数之和。
【输出10个数】:输出1到10十个数字,中间用回车隔开。

/*
    Coded by Ice_teapoy
*/
#include 
#include 
//读入优化
inline char getcha()
{
    static char qwq[100000],*p1=qwq,*p2=qwq;
    return p1==p2&&(p2=(p1=qwq)+fread(qwq,1,100000,stdin),p1==p2)?EOF:*p1++;
}
int read()
{
    int res=0,f=1;
	char x=getcha();
    for (;!isdigit(x);x=getcha()) (x=='-')&&(f=-1);
    for (;isdigit(x);x=getcha()) res=(res<<3)+(res<<1)+(x^48);
    return f*res;
}
//输出优化
char pqwq[100000],*pp=pqwq;
void push(const char c)
{
    if (pp-pqwq==100000) fwrite(pqwq,1,100000,stdout),pp=pqwq;
    *pp++=c;
}
void write(int x)
{
    static int aa[35];
    int top=0;
    do aa[top++]=x%10,x/=10;
	while(x);
    while(top) push(aa[--top]+'0');
}
int main()
{
	//a+b问题 
	int a=read(),b=read();
	write(a+b);
	fwrite(pqwq,1,pp-pqwq,stdout);
	pp=pqwq;
	//一行一个输出1-10
	for (int i=1;i<=10;++i)
	{
		puts(""),write(i);
		fwrite(pqwq,1,pp-pqwq,stdout);
		pp=pqwq;
	}
}

【实数读入优化】

【a+b问题】:读入两个数,输出两数之和。

#include 
#include 
inline double readb()
{
    double sum=0,Y=1.0;
    int f=1;
    char x=0;
    for (;!isdigit(x);x=getchar()) x=='-'?f=-1:1;
    for (;isdigit(x);x=getchar()) sum=sum*10+(x^48);
    x=getchar();
    for (;isdigit(x);x=getchar()) sum+=(Y/=10)*(x^48);
    return f*sum;
}
int main()
{
	double a=readb(),b=readb();
	printf("%.2lf",a+b);
} 

你可能感兴趣的:(沉迷打板子无法自拔)