2016-09-18 5 views
0

Я пробовал 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 

Я работал на этом навсегда и я искал каждый форум, что я мог бы но я не могу понять, что мне не хватает.

ответ

1

Сегментация Fault **

Вы получаете ошибку сегментации, когда вы проходите NULL к atoi. Это происходит потому, что ограничения в вашей петле неверны. Это:

for (int j = 1; j <= argc; j++) 

вместо этого должен быть

for (int j = 1; j < argc; j++) 

В C, вы должны относиться к все петли с <= завершающего состояния с крайним подозрением. Чаще всего здесь скрывается ошибка.

+0

Спасибо! Я подумал, что это будет что-то смехотворно простое. – MadelineStates