T500000 500000 题解

目前最优解:4ms

若有更有解法,请私信 sLMxf。

subtask 1

直接输出 500000500000500000500000,代码如下:

#include<bits/stdc++.h>
using namespace std;
void write(int x)
{
    if(x<0)
        putchar('-'),x=-x;
    if(x>9)
        write(x/10);
    putchar(x%10+'0');
    return;
}
main()
{
	for(int i=1;i<=500000;i++)
	{
	    write(500000);
	    printf(" ");
	}
	return 0;
}

用时:17ms。

subtask 2

以字符串的形式输出。

#include<bits/stdc++.h>
#define int long long
using namespace std;
signed main()
{
	for(int i=1;i<=500000;i++) cout<<"500000 ";
	return 0;
}

用时:13ms。

subtask 3

经过试验之后,我们可以发现一次多输出一点内容效率会提高(毕竟 ii 加的次数变少了)。所以可以得到如下代码:

#include<bits/stdc++.h>
#define int long long
using namespace std;
signed main()
{
	for(int i=1;i<=250000;i++) cout<<"500000 500000 ";
	return 0;
}

用时:9ms。

subtask 4

考虑继续缩减,比如 1010 个一次。

#include<bits/stdc++.h>
#define int long long
using namespace std;
signed main()
{
	for(int i=1;i<=25000;i++)
	    cout<<"500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 ";
	return 0;
}

用时:5ms。

subtask 5 by Grow2011

按照分块的思路,分成 500000\sqrt{500000} 块肯定较优,这里选择的是 10001000。接着考虑优化常数。bits/stdc++.h 头文件可以换成 iostreamint 换成 register intsigned main 换成 main。代码如下:

#include<iostream>
using namespace std;

main(){
	for(register int i = 1;i<=1000;++i)printf("500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 500000 ");
	return 0;
}

用时:4ms。

posted @ 2024-08-18 21:11  sLMxf  阅读(25)  评论(0)    收藏  举报  来源