Я пробовал atoi, strol и stoi, но никто из них не работает для меня. Я даже попытался вычесть «0» из char, который, как я слышал, должен работать, но это тоже заставило ошибку. atoi дает мне ошибку сегментации, strol не будет компилироваться, а stoi дает мне логическую ошибку std. вот вся моя программа, как прямо сейчас:Преобразование аргументов argv в int
#include <iostream>
#include <string>
#include <stdlib.h>
using namespace std;
bool isPrime(int);
int main (int argc, char *argv[])
{
const int size = 199;
int counter = 1;
int primeAry[size];
for (int i = 0; i < size; i++) // creates an array of prime numbers
{
if (isPrime(i))
{
primeAry[counter] = i;
counter++;
}
}
for (int j = 1; j <= argc; j++) // finds prime numbers by index of args and displays them
{
if (j == 1)
cout << "Last name is " << argv[j] << endl;
else
{
int temp = atoi(argv[j]);
cout << temp << " th prime number is " << primeAry[temp] << endl;
}
}
system("pause");
return 0;
}
bool isPrime(int num)
{
if(num <= 1)
return false;
else if (num <= 3)
return true;
else if (((num % 2) == 0) || (num % 3) == 0)
return false;
int i = 5;
while((i*i) <= num)
{
if ((num % i == 0) || ((num % (i + 2)) == 0))
return false;
i = i + 6;
}
return true;
}
И вот результат я получаю:
Last name is smith
1 th prime number is 2
2 th prime number is 3
3 th prime number is 5
Segmentation Fault
Я работал на этом навсегда и я искал каждый форум, что я мог бы но я не могу понять, что мне не хватает.
Спасибо! Я подумал, что это будет что-то смехотворно простое. – MadelineStates