- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在 C++ 中添加两个多项式,但我不知道从哪里开始。因此用户可以输入多项式的值,它们不需要按顺序或其他任何东西。
例如可以是:多边形 1:2x^5 + 5x^2 - 2x + 9保利 2: x^2 + 0
我将系数和指数存储在类(对象)私有(private)字段中。那么我是否会查看 Poly 1 中的第一个指数,首先在 Poly 2 中搜索相同的指数,如果找到则添加它们?然后继续第二学期?
请求的代码:(注意:目前的实现是错误的,我需要有关如何解决此问题的帮助。)
#include <cmath>
#include <iostream>
using namespace std;
class polynomial
{
public:
polynomial();
polynomial(int);
polynomial(int exponent[], int coefficient[], int);
~polynomial();
polynomial &operator = (const polynomial &obj);
int evaluate(double uservalue);
polynomial operator+(const polynomial &obj) const;
void operator-(const polynomial &obj) const;
void operator*(const polynomial &obj) const;
friend istream & operator>> (istream & in, polynomial &obj);
friend ostream & operator<< (ostream & out, const polynomial &obj);
friend void growone(polynomial &obj);
private:
int *coefficient;
int *exponent;
int size;
};
和实现
polynomial polynomial::operator+(const polynomial &obj) const
{
bool matchFound = false;
polynomial tmp;
if (size >= obj.size) {
for (int i = 0; i < size; i++) {
if (i >= tmp.size) {
growone(tmp);
}
for(int y = 0; i < obj.size; i++) {
if (exponent[i] == obj.exponent[y]) {
tmp.coefficient[i] = (coefficient[i]+obj.coefficient[y]);
tmp.exponent[i] = exponent[i];
tmp.size++;
matchFound = true;
}
}
if (matchFound == false) {
tmp.coefficient[i] = coefficient[i];
tmp.exponent[i] = exponent[i];
tmp.size++;
}
matchFound = false;
}
} else {
}
return tmp;
}
最佳答案
您并没有真正充分利用 C++ 的强大功能。一个好的规则是,如果您将非智能指针用于任何东西,您应该退后一步并重新考虑。
Stack Overflow 上关于 C 的大量问题都与指针有关的问题绝非偶然:-)
我要补充的另一点是,实际上浪费少量内存来大大简化您的代码可能是值得的。也就是说,我的意思是不要尝试创建稀疏数组来保存您的项(系数指数对)。相反,允许每个表达式将每个项保持到其最大值,将未使用项的系数简单地设置为零。除非你有类似 4x<sup>99999999999999</sup> + 3
的表达,占用的额外内存量可能是值得的。
为此,我建议使用 std::vector
对于仅从零指数开始的系数。指数实际上是由 vector 中的位置决定的。所以表达式 4x<sup>9</sup> - 17x<sup>3</sup> + 3
将被存储为 vector :
{3, 0, 0, -17, 0, 0, 0, 0, 0, 4}
0 <------- exponent -------> 9
这实际上使加减多项式的任务变得异常容易,因为系数都排列得很好。
因此,考虑到这一点,让我们介绍一个简化的类来展示它是如何完成的:
#include <iostream>
#include <vector>
using std::cout;
using std::vector;
using std::ostream;
class Polynomial {
public:
Polynomial();
Polynomial(size_t expon[], int coeff[], size_t sz);
~Polynomial();
Polynomial &operator=(const Polynomial &poly);
Polynomial operator+(const Polynomial &poly) const;
friend ostream &operator<<(ostream &os, const Polynomial &poly);
private:
std::vector<int> m_coeff;
};
默认构造函数(和析构函数)非常简单,我们只需确保初始化的多项式始终至少有一项:
Polynomial::Polynomial() { m_coeff.push_back(0); }
Polynomial::~Polynomial() {}
constructor-from-array 稍微复杂一些,因为我们希望尽早将用户的“随心所欲”格式转换为我们可以轻松使用的格式:
Polynomial::Polynomial(size_t expon[], int coeff[], size_t sz) {
// Work out largest exponent and size vector accordingly.
auto maxExpon = 0;
for (size_t i = 0; i < sz; ++i) {
if (expon[i] > maxExpon) {
maxExpon = expon[i];
}
}
m_coeff.resize(maxExpon + 1, 0);
// Fill in coefficients.
for (size_t i = 0; i < sz; ++i) {
m_coeff[expon[i]] = coeff[i];
}
}
现在您将明白为什么我们决定不使用稀疏数组并将零指数放在 vector 的开头。博特operator=
和 operator+
很简单,因为他们已经知道所有术语在哪里:
Polynomial &Polynomial::operator=(const Polynomial &poly) {
if (this != &poly) {
m_coeff.clear();
for (int coeff: poly.m_coeff) {
m_coeff.push_back(coeff);
}
}
return *this;
}
Polynomial Polynomial::operator+(const Polynomial &poly) const {
// Create sum with required size.
size_t thisSize = this->m_coeff.size();
size_t polySize = poly.m_coeff.size();
Polynomial sum;
if (thisSize > polySize) {
sum.m_coeff.resize(thisSize, 0);
} else {
sum.m_coeff.resize(polySize, 0);
}
// Do the actual sum (ignoring terms beyond each limit).
for (size_t idx = 0; idx < sum.m_coeff.size(); ++idx) {
if (idx < thisSize) sum.m_coeff[idx] += this->m_coeff[idx];
if (idx < polySize) sum.m_coeff[idx] += poly.m_coeff[idx];
}
return sum;
}
现在我们只需要用一个输出函数和一个小的测试主线来完成这个:
ostream &operator<< (ostream &os, const Polynomial &poly) {
bool firstTerm = true;
if (poly.m_coeff.size() == 1 && poly.m_coeff[0] == 0) {
os << "0";
return os;
}
for (size_t idx = poly.m_coeff.size(); idx > 0; --idx) {
if (poly.m_coeff[idx - 1] != 0) {
if (firstTerm) {
os << poly.m_coeff[idx - 1];
} else if (poly.m_coeff[idx - 1] == 1) {
os << " + ";
if (idx == 1) {
os << poly.m_coeff[idx - 1];
}
} else if (poly.m_coeff[idx - 1] == -1) {
os << " - ";
} else if (poly.m_coeff[idx - 1] < 0) {
os << " - " << -poly.m_coeff[idx - 1];
} else {
os << " + " << poly.m_coeff[idx - 1];
}
if (idx > 1) {
os << "x";
if (idx > 2) {
os << "^" << idx - 1;
}
}
firstTerm = false;
}
}
return os;
}
int main() {
int c1[] = {1, 2, 3, 4, 5};
size_t e1[] = {3, 1, 4, 0, 9};
Polynomial p1(e1, c1, (size_t)5);
cout << "Polynomial 1 is " << p1 << " (p1)\n";
int c2[] = {6, 7, 8};
size_t e2[] = {3, 7, 9};
Polynomial p2(e2, c2, (size_t)3);
cout << "Polynomial 2 is " << p2 << " (p2)\n";
Polynomial p3 = p1 + p2;
cout << "Polynomial 3 is " << p3 << " (p3 = p1 = p2);
}
我稍微重新格式化以显示类似术语的输出显示了它的实际效果:
Polynomial 1 is 5x^9 + 3x^4 + x^3 + 2x + 4
Polynomial 2 is 8x^9 + 7x^7 + 6x^3
===================================
Polynomial 3 is 13x^9 + 7x^7 + 3x^4 + 7x^3 + 2x + 4
关于C++ 多项式加法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28378085/
我正在尝试将父 div 标记的最小宽度设置为内部所有子项的等效宽度。有办法吗? 例如, #sidebar{ width: 325px; } #content{ width: 500
我正在其中一个脚本中做一些附加操作,下面是一些简化的代码: foreach($entry in $arr){ ... switch($entry.AccessRights) { "GenericRea
float 在我的 Java/JOGL (OpenGL for Java) 程序中没有按预期计算。在绘制方法中,当调用每一帧(每秒 60 帧)时,我尝试修改对象的位置。所有值都是浮点值。 float
我正在尝试使用 C 中的结构为一个项目进行复杂的 vector 加法和点积。我已经编写了代码,但是,虽然它的编译没有问题,但一旦我运行我的程序,它就会停止工作。我还有该程序的其他部分,但这只是相关部分
这个问题已经有答案了: Use of java.math.MathContext (5 个回答) 已关闭 8 年前。 首先,我的搜索能力可能没有我希望的那么好,所以也许这种问题已经存在了。如果是的话请
PFB 说明问题的示例代码片段: var x=0.323; var cumulativeVal = 0; for(i=0;i<30;i++){
这个查询的每一步在 PostgreSQL 中的执行顺序是什么? SELECT SUM(field1)+SUM(field2)+SUM(field3)-SUM(field4); 据我所知,加法/减法是按
我正在尝试熟悉 Java 多线程应用程序。我试图想出一个可以很好地并行化的简单应用程序。我认为 vector 加法是一个很好的应用。但是,在我的 Linux 服务器(有 4 个内核)上运行时,我没有得
我在进行简单的加法并将值保存在变量中时遇到问题。 基本上我有以下代码: var accsen; var lowsev = parseInt(accsen); var hisev
所以我最近几个小时一直在解决一个问题,似乎无法阻止我的程序崩溃。问题是创建一个程序,该程序采用任意大小的矩阵,并且能够使用运算符重载将一个矩阵加到另一个矩阵上。当我尝试添加我类(class)的两个对象
我正在尝试添加以下内容,但它一直连接并返回一个字符串。 var nums = [1.99, 5.11, 2.99]; var total = 0; nums.forEach(f
我在网上搜索了数据仓库中加法、半加法和非加法度量之间的区别。我找到了一些结果,但我很难理解这些差异,因为它们不是一个例子。您能否通过示例向我更多地解释加法、半加法和非加法措施之间的区别。 最佳答案 T
%{control.current + #displayRows} 最终是我需要执行的语句。我将其放在 s:if 标记中,并使用 test 来查看该值是否在特定范围内。 最终,我得到的是字符串连接而不
请帮助我解释为什么下面的代码会得到奇怪的输出......为什么 getName() 得到 null。 输出: 列表检查:null:1 public class ListTest { public st
我需要通过字典生成校验和。键和值。 是否有任何简单的方法以迭代方式完成此任务。 foreach(dic.Keys 中的变量项) 校验和 += 校验和(dic[item]) + 校验和(item); 在
我想计算平均销售产品数量。表: pieces | date | status ------------------------------------------- 1
我正在尝试从 mysql 获取 INT 值并进行添加,最后更新数据库。不过这个好像没有更新?我该如何解决这个问题? $resultSecond = mysql_query("SELECT * FROM
我遇到了一个奇怪的问题。 有一张图片,我只需要重新计算非零像素。我想通过 numpy 来完成,因为我处理了数千张图像并且我需要它的速度。 这是一个维度较低的简化示例。 假设我有以下矩阵: [[0,
我不确定下一步该做什么。它们只是文本字段中的美元金额。我正在尝试将它们加在一起。 NSString *checkAmount = [checkAmountInput.text substringFro
我正在测试我的一些代码,在 javascript 中我添加了 .1+.2 ,它给了我 .30000000000000004 而不是 .3 。我不明白这一点。但是当我添加 .1+.3 时,它给了我 .4
我是一名优秀的程序员,十分优秀!