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
我一直對這種永遠和我已經搜查每一個論壇上,我可以發現但我無法弄清楚我錯過了什麼。
謝謝!我認爲這將是一件非常簡單的事情。 – MadelineStates