2016-09-18 124 views
0

我嘗試過atoi,strol和stoi,但是他們都沒有爲我工作。我甚至試圖從我聽到的字符中減去'0'應該工作,但也拋出了一個錯誤。 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

分段錯誤**

你得到段錯誤當你通過NULLatoi。這是因爲你的循環邊界不正確。這:

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

應改爲

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

在C語言中,你應該把所有循環與極端懷疑<=終止條件。通常情況下,這是錯誤隱藏的地方。

+0

謝謝!我認爲這將是一件非常簡單的事情。 – MadelineStates