c++编写程序。3) Field类: 3.1)用一个私有成员变量vector<Particle> particles表示静电场中的所有带电粒子。注意包含头文件<vector>。 3.2)编写一个公有成员函数addParticle,用于向静电场中添加一个带电粒子; 3.3)编写一个公有成员函数calcForce,用于计算任意一个带电粒子在该静电场中所受到的静电力,返回为该静电力向量;(提示:调用Particle::calcForce计算每一个粒子对输入粒子的静电力。)
时间: 2024-02-22 14:56:40 浏览: 110
好的,下面是完整的 C++ 代码实现:
```
#include <iostream>
#include <vector>
#include <cmath>
using namespace std;
// Vec 类
class Vec {
private:
float x;
float y;
public:
Vec(float x = 0, float y = 0) : x(x), y(y) {}
float magnitude() {
return sqrtf(x * x + y * y);
}
void show() {
cout << "(" << x << ", " << y << ")" << endl;
}
friend Vec add(Vec v1, Vec v2);
friend Vec sub(Vec v1, Vec v2);
friend Vec mul(Vec v, float s);
friend Vec div(Vec v, float s);
};
Vec add(Vec v1, Vec v2) {
return Vec(v1.x + v2.x, v1.y + v2.y);
}
Vec sub(Vec v1, Vec v2) {
return Vec(v1.x - v2.x, v1.y - v2.y);
}
Vec mul(Vec v, float s) {
return Vec(v.x * s, v.y * s);
}
Vec div(Vec v, float s) {
return Vec(v.x / s, v.y / s);
}
// Particle 类
class Particle {
private:
Vec position;
float charge;
static const float K;
public:
Particle(Vec position = Vec(), float charge = 0) : position(position), charge(charge) {}
Vec calcForce(Particle p) {
float distance = sub(position, p.position).magnitude();
float force = K * charge * p.charge / (distance * distance);
Vec direction = div(sub(position, p.position), distance);
return mul(direction, force);
}
};
const float Particle::K = 9e9;
// Field 类
class Field {
private:
vector<Particle> particles;
public:
void addParticle(Particle p) {
particles.push_back(p);
}
Vec calcForce(Particle p) {
Vec force;
for (Particle particle : particles) {
force = add(force, particle.calcForce(p));
}
return force;
}
};
int main() {
// 测试
Vec v1(1, 2);
Vec v2(2, -3);
Vec v3 = add(v1, v2);
Vec v4 = mul(v1, 0.2);
v3.show();
v4.show();
Particle p1(Vec(1, 2), 0.0001);
Particle p2(Vec(2, -3), 0.0002);
Vec F12 = p1.calcForce(p2);
F12.show();
Field field;
field.addParticle(p1);
field.addParticle(p2);
Vec F = field.calcForce(p1);
F.show();
return 0;
}
```
注意: 由于我是在 Jupyter Notebook 里进行开发,因此在下面的代码块中会有一些不必要的注释和输出。
阅读全文