다항식에서 coeffecients 및 지수의 값을 추출하려고합니다. 나는 이미 strtok
을 사용하여 계수들을 추출하는데 성공했다. 지수를 찾기 위해 같은 개념을 적용했지만, strtok
을 사용하여 구분 기호 뒤에 문자열을 추출하거나 첫 번째 문자를 건너 뛰는 방법을 모르며, 내가 알고있는 유일한 추출 도구는 strtok
입니다.C 문자열을 사용하여 다항식 C++에서 지수를 추출하십시오.
이이 함수가 COEFF를 추출하는 것입니다
#include <iostream>
#include <cctype>
#include <cstring>
#include <cstdlib>
#include <string>
using namespace std;
void extractCoeff (char *str, char *copy);
void extractExp (char *str, char *copy);
int main()
{
const int SIZE = 150; // size for string input
char *string;
string = new char[SIZE];
cout << "Enter the polynomial\n"<<"minus sign must not have a blank with a coeff";
cin.ignore();
cin.getline(string, SIZE); // input string example: -4x^0 + x^1 + 4x^3 -3x^4
char *copy1;
copy1 = new char[SIZE];
strcpy(copy1, string);
extractCoeff(string, copy1);
cout << endl << endl;
char *copy2;
copy2 = new char[SIZE];
strcpy(copy2, string);
extractExp(string, copy2);
return 0;
}
주요 기능을이다
void extractCoeff (char *str, char *copy)
{
char *p = strtok(str, " +"); // extract the first time
char *search;
int counter = 0;
while (p)
{
search = strstr(p, "x^");
cout << "Token: " << p << endl;
cout << "Search " << search << endl;
p = strtok(NULL, " +");
counter++;
}
cout << copy << endl;
// find coeff
int *coefficient;
coefficient = new int[counter];
p = strtok(copy, " +"); // extract the second time to find coeff
int a = 0;
while (p)
{
cout << "p: " << p << endl;
long coeff;
if (*p == 'x')
{
coeff = 1;
}
else if (*p == NULL)
{
coeff = 0;
}
else
{
char *endptr;
coeff = strtol(p, &endptr, 10);
}
coefficient[a] = coeff;
p = strtok(NULL, " +");
a++;
}
for (int i = 0; i < counter; i++)
cout << coefficient[i] << endl;
}
이것은 (작동하지 않는) 지수
void extractCoeff (char *str, char *copy)
{
char *p = strtok(str, " +"); // extract the first time
char *search;
int counter = 0;
while (p)
{
search = strstr(p, "x^");
cout << "Token: " << p << endl;
cout << "Search " << search << endl;
p = strtok(NULL, " +");
counter++;
}
cout << copy << endl;
// find coeff
int *coefficient;
coefficient = new int[counter];
p = strtok(copy, " +"); // extract the second time to find coeff
int a = 0;
while (p)
{
cout << "p: " << p << endl;
long coeff;
if (*p == 'x')
{
coeff = 1;
}
else if (*p == NULL)
{
coeff = 0;
}
else
{
char *endptr;
coeff = strtol(p, &endptr, 10);
}
coefficient[a] = coeff;
p = strtok(NULL, " +");
a++;
}
for (int i = 0; i < counter; i++)
cout << coefficient[i] << endl;
}
void extractExp (char *str, char *copy)
{
char *p = strtok(str, " x^"); // extract the first time
//char *search;
int counter = 0;
while (p)
{
//search = strstr(p, "x^");
//cout << "Token: " << p << endl;
//cout << "Search " << search << endl;
p = strtok(NULL, " x^");
counter++;
}
cout << copy << endl;
// find coeff
int *exp;
exp = new int[counter];
p = strtok(copy, " x^"); // extract the third time
int b = 0;
while (p)
{
cout << "p2: " << p << endl;
int expVal;
if (*p == NULL)
{
expVal = 0;
}
else
{
char *endptr;
expVal = strtol(p, &endptr, 10);
}
exp[b] = expVal;
p = strtok(NULL, " x^");
b++;
}
for (int i = 0; i < counter; i++)
cout << exp[i] << endl;
}
"작동하지 않는 방법"을 알려주십시오. 너는 무엇을 기대하니, 너는 무엇을 얻 느냐? – JoergB
정규 표현식을 사용하여 전체 입력을 구문 분석하는 것이 더 좋은 방법 일 수 있습니다. 예를 들어 ['boost :: regex'] (http://www.boost.org/doc/libs/1_53_0/libs/regex/doc/html/index.html), 또는 새로운 C + +에서'std :: regex' +11 표준. –