如何解决黑客兰克"terminated for timeout"?
how can i resolve Hackerrank "terminated for timeout"?
问题是找出不可逆的不。S下面的测试用例,这里是可逆的。s表示像36 + 63 = 99
(同时包含奇数)。36
和63
都是可逆的。我们要找到所有可逆的no
我也声明函数为inline
,但它仍然给出超时错误。从测试用例#1到测试用例#5
inline std::string IntToString ( int number )
{
std::ostringstream oss;
oss<< number;
return oss.str();
}
inline int replacer (int n)
{
int r,R=0;
while(n!=0)
{
r=n%10 ;
R=R*10+r ;
n=n/10;
}
return R ;
}
int main() {
/* Enter your code here. Read input from STDIN. Print output to STDOUT */
int i,n,t,j,R,Q,L,k,d=0,M=0,D;
cin>>t ;
for(i=0;i<t;i++ )
{
M=0;
cin>>n ;
for(j=1;j<n;j++)
{
if(j%10!=0)
{ d=0;
R= replacer(j) ;
Q=R+j ;
std::string C = IntToString (Q);
L=C.size() ;
for(k=0;k<L;k++)
if(C[k]%2==0)
d=1 ;
if(d==0)
M++ ;
}
}
cout<<M<<endl ;
}
return 0;
}
一个简单的通用答案是"通过使你的代码快速做事",即通过优化它。
分析工具可以帮助您指出代码的"热点"部分,但是解析必须由您自己完成。
您不需要有字符串来获取数字的位数。考虑到使用流,将int转换为string是一个开销很大的操作。如果你想循环一个数字的位数,使用这段代码:
void loopThroughDigits(int n)
{
while(n > 0)
{
int digit = n % 10;
n /= 10;
//do something with digit
}
}
除此之外,您应该考虑存储之前的结果,并从之前的"检查点"开始计算。我既不知道内存限制也不知道最大输入,所以我不确定这是一个可靠的方法。
相关文章:
- "error: no matching function for call to"构造函数错误
- 表示"accepting anything for this template argument" C++概念的通配符
- 如何在C++中从两个单独的for循环中添加两个数组
- 在Linux for Windows上编译C++代码时出错
- 调用专用模板时出错"no matching function for call to [...]"
- 为什么我的for循环不能正确获取argv
- 为什么我不能在 FOR LOOP 中使用 i/10,C++?
- Arduino:for/while/if在void setup()或void loop()之前?——错误:之前需要不合格
- 在基于范围的for循环中使用结构化绑定声明
- 通过for循环使用用户输入填充列表
- 使用for循环检查数组中的重复项
- 在for循环中使用auto vs decltype(vec.size())来处理字符串的向量
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 正在使用for循环创建QScatterSerie
- Python中的for循环与C++有何不同
- std::memory_order for std::atomic:<T>:wait
- 在更改for循环的第三部分后,未使用for循环结果
- 在 for 循环中查找问题时遇到困难
- 嵌套for循环C++的问题(初学者)
- 如何解决黑客兰克"terminated for timeout"?