为什么我的代码在SPOJ上给出错误的答案
Why my code is giving wrong answer on SPOJ?
问题:http://www.spoj.com/problems/TSORT/
下面的代码在我的计算机上给出了正确的输出,但在spoj上给出了错误的答案。我已经尝试了几个输入,它给出了正确的输出。但是在spoj上仍然显示错误答案。
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
int t;
cin>>t;
cin.tie(0);
ios::sync_with_stdio(false);
int *arr= new int[t];
for(int i=0;i<t;i++)
{
cin>>arr[i];
}
sort(arr,arr+t);
for(int i=0;i<t;i++)
{
cout<<"n";
cout<<arr[i];
}
return 0;
}
正如Tejas所说,在优化问题中不建议使用cin和cout,因为与扫描和打印相比,它们更慢。扩展他的答案,您需要注意您使用的STL sort
比STL qsort
慢。考虑到这一点,我用qsort
尝试了你的代码,我得到了AC:
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstdlib>
using namespace std;
int a[1000008];
int compare (const void * a, const void * b)
{
return ( *(int*)a - *(int*)b );
}
int main()
{
int n,i;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
qsort(a,n,sizeof(int),compare);
for(i=0;i<n;i++)
printf("%dn",a[i]);
return 0;
}
int
函数compare
需要qsort
的使用。
更多信息:
http://www.cplusplus.com/reference/cstdlib/qsort/http://www.cplusplus.com/reference/algorithm/sort/如果您使用cout<<arr[i]<<endl;
,它将给出TLE而不是WA。所以这意味着它与新行有关。
然而,如果你想让你的答案被接受,你必须使用printf和scanf而不是cin, cout。在这样的竞赛中,总是建议使用scanf和printf来读取大的输入。
我尝试了下面的代码,它被接受了
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
int a[1000008];
int main()
{
int n,i;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
sort(a,a+n);
for(i=0;i<n;i++)
printf("%dn",a[i]);
return 0;
}
相关文章:
- 分段错误当我试图运行程序时出错
- .h 和.cpp文件分离时出错,但仅使用 .h 文件时没有错误.我做错了什么?
- 创建 OpenCV 非自由版本 v4.3 时出错,可折叠.cpp错误 C2039、2605
- 制作时出错,C++"db.c:2127:错误:在"||"标记之前应使用";"
- C++语法错误,编译器不会警告或 int v = func(&v) 出错;
- 在VS2015中访问类成员时运行时错误,但在Linux上未访问时出错
- 如何更改路径以修复错误"./main:加载共享库 libmkl_core.so 时出错?
- 为什么在定义类之前声明类的对象会在友元类中给出错误,而在友元函数中不会出错
- 安装 mply 库时出错.致命错误:gsl/gsl_sf.h:没有这样的文件或目录
- Rcpp/C++/R:比较日期时间矢量与日期时间时出错(错误:"运算符>"的不明确重载)
- 编译特征程序时出错:错误:'seq'不是'Eigen'的成员
- 可能的 GCC 链接器错误会导致将弱符号和局部符号链接在一起时出错
- 非标准语法;使用 '&' 创建指向成员的指针错误,将成员函数分配给向量时出错
- 运算符重载时出错(错误:"运算符<<不匹配(操作数类型为"std::basic_ostream<char>"和"const char [2]")
- 编译类 C++ 中的线程时出错(错误 xthread)
- 加载GLEW库时出错(错误LNK2001)
- 通过函数指针调用函数时出错(错误C2064)
- 编译core.obj时出错:错误LNK2001:未解析的外部符号_harmony_core_init
- 链接c++静态库与android ndk时出错(错误:无法识别文件格式)
- 使用GCC编译游戏时出错.(错误:将"Screen"的含义从"class Screen&q