显示来自 abort(3) (SIGABRT) 的 Runtime ErrorAbort 信号
Showing Runtime ErrorAbort signal from abort(3) (SIGABRT)
// Sum of Sub-Array
#include<iostream>
#include<vector>
using namespace std;
void firstSubArray(vector<int> arr, int size, int sum)
{
int newSum = 0;
int beginPos=0;
for(int i = 0; i<size; i++)
{
newSum += arr.at(i);
if(newSum > sum)
{
newSum = newSum - arr.front();
arr.erase(arr.begin());
beginPos++;
}
if(newSum == sum) {
cout << beginPos + 1 << " " << i + 1;
return;
}
}
cout<<"-1";
}
int main()
{
int testCases;
cin>>testCases;
int size, sum;
int temp;
for(int j = 0; j<testCases; j++) {
cin>>size>>sum;
vector<int>arr;
for (int i = 0; i < size; i++) {
cin >> temp;
arr.push_back(temp);
}
firstSubArray(arr, size, sum);
cout<<endl;
}
return 0;
}
问题:给定一个大小为 N 的非负整数的未排序数组 A,找到一个连续的子数组,它与给定的数字 S 相加。我的代码给出了正确的答案对于给定的测试用例,但在提交时显示 运行 时间错误。
错误:
运行时错误:
来自 abort(3) (SIGABRT)
的运行时错误中止信号
Link: Question Link
您正在尝试访问向量中不存在的位置。服务器上的执行程序检测到这种情况并中止。第一步,将 arr
更改为 vector < int > const &arr
。
// Sum of Sub-Array
#include<iostream>
#include<vector>
using namespace std;
void firstSubArray(vector<int> arr, int size, int sum)
{
int newSum = 0;
int beginPos=0;
for(int i = 0; i<size; i++)
{
newSum += arr.at(i);
if(newSum > sum)
{
newSum = newSum - arr.front();
arr.erase(arr.begin());
beginPos++;
}
if(newSum == sum) {
cout << beginPos + 1 << " " << i + 1;
return;
}
}
cout<<"-1";
}
int main()
{
int testCases;
cin>>testCases;
int size, sum;
int temp;
for(int j = 0; j<testCases; j++) {
cin>>size>>sum;
vector<int>arr;
for (int i = 0; i < size; i++) {
cin >> temp;
arr.push_back(temp);
}
firstSubArray(arr, size, sum);
cout<<endl;
}
return 0;
}
问题:给定一个大小为 N 的非负整数的未排序数组 A,找到一个连续的子数组,它与给定的数字 S 相加。我的代码给出了正确的答案对于给定的测试用例,但在提交时显示 运行 时间错误。
错误: 运行时错误: 来自 abort(3) (SIGABRT)
的运行时错误中止信号Link: Question Link
您正在尝试访问向量中不存在的位置。服务器上的执行程序检测到这种情况并中止。第一步,将 arr
更改为 vector < int > const &arr
。