思考题1
data:image/s3,"s3://crabby-images/7c2e1/7c2e1e4bd66ffc0cba2c51800e30fb4252fd27c3" alt=""
data:image/s3,"s3://crabby-images/958d9/958d926a7334f058fba0dd696bec82f57b51abd5" alt=""
改进cosx?优化算法
关键点在于cos计算过于麻烦,而每次都要求sinx的值
故直接简化为cosx的导数 -sinx
即:
原://double daoshu(double x) {
// return 18 * x - cos(x);
//}
改:double daoshu(double x) {
return 18 * x + sin(x);
}
data:image/s3,"s3://crabby-images/f81eb/f81ebac0d245fac0d3b92411958a0d77532740a1" alt=""
证明:
data:image/s3,"s3://crabby-images/c27cc/c27cc51e78f79a682fe380133e3fc90482e88852" alt=""
思考题2:
data:image/s3,"s3://crabby-images/d8c75/d8c7505a06f0ced90dc8b155ac9c7ff5570859a3" alt=""
cpp
c++代码如下:
// 二分法
double bin(double l, double r) {
double eps = 1e-3;
while (r - l > eps) {
double mid = (l + r) / 2;
double f = exp(mid) + 10 * mid - 2;
if (f > 0) {
r = mid;
} else {
l = mid;
}
}
return (l + r) / 2;
}
// 迭代法
double ite() {
double x = 0;
double eps = 1e-3;
while (1) {
double x1 = (2 - exp(x)) / 10;
if (x - x1 > eps) {
break;
}
x = x1;
}
return x;
}
// 牛顿法
double new() {
double x = 0;
double eps = 1e-3;
while (1) {
double f = exp(x) + 10 * x - 2;
double df = exp(x) + 10;
double x1 = f / df;
if (x1 > eps) {
break;
}
x = x - x1;
}
return x;
}
data:image/s3,"s3://crabby-images/a093b/a093b6c9b93148f206dff0272c2d50990dfff6dd" alt=""
思考题3:
求谱半径?
data:image/s3,"s3://crabby-images/0054c/0054c9c5c238551ab4836003b59f41918ac16b85" alt=""
思考题4:
data:image/s3,"s3://crabby-images/1005c/1005c656f90a81858503968ad335d02fa38306cc" alt=""
data:image/s3,"s3://crabby-images/b86d7/b86d72917371875cf5b34643da7cfb3fe1d7fe1e" alt=""
data:image/s3,"s3://crabby-images/266ab/266ab79f9607e90401e8cd2ae6b5fe2a67e61ce3" alt=""
代码实现:
cpp
double Max(vectorx) {
double max = x[0];
int n = x.size();
for (int i = 0; i < n; i++)
if (x[i] > max) max = x[i];
return max;
}
void Jacobi(vector<vector > A, vector B, int n) {
vector X(n, 0);
vector Y(n, 0);
vector D(n, 0);
int k = 0;
do {
X = Y;
for (int i = 0; i < n; i++) {
double tem = 0;
for (int j = 0; j < n; j++) {
if (i != j) tem += A[i][j] * X[j];
}
Y[i] = (B[i] - tem) / A[i][i];
cout << left << setw(8) << Y[i] << " ";
}
cout << endl;
k++;
if (k > 100) {
return;
}
for (int a = 0; a < n; a++) {
D[a] = X[a] - Y[a];
}
} while (fabs(Max(D)) > 1e-4);
return;
}
int main() {
int n;
cout << "未知数的个数n:";
cin >> n;
cout << endl;
vector<vector>A(n, vector(n, 0));
vectorB(n, 0);
cout << "系数矩阵:" << endl;
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
cin >> A[i][j];
}
}
cout << endl;
cout << "值矩阵:" << endl;
for (int k = 0; k < n; k++) {
cin >> B[k];
}
cout << endl;
cout << "您输入的方程组为:" << endl;
for (int a = 0; a < n; a++) {
for (int b = 0; b < n; b++) {
cout << A[a][b] << " ";
}
cout << " " << B[a] << endl;
}
cout << endl;
cout << "方程组的解:" << endl;
Jacobi(A, B, n);
return 0;
}
结果:
思考题5:
.ACM 大赛预测计算名次
甲第一,乙第三。
丙第一,丁第四。
丁第二,甲第三。
都只说对一半
计算名次
代码:
cpp
int main()
{
//甲乙丙丁:ABCD
int a,b,c,d;
for(a=1;a<=4;++a)
{
for(b=1;b<=4;++b)
{
if(a!=b)
for(c=1;c<=1;++c)
{
d=10-a-b-c;
if(((a==1)+(b==3)==1)&&( (c==1)+(d==4 )==1)&&((a==3)+(d==2)==1 ) )
{
cout<<"甲:"<<a<<"乙:"<<b<<"丙:"<<c<<"丁:"<<d<<endl;
break;
}
}
}
}
return 0;
}
结果:
思考题6:
data:image/s3,"s3://crabby-images/7e589/7e58901d962c7b388eb561e078dfed6ce2f889cd" alt=""
思考题7:
data:image/s3,"s3://crabby-images/0932d/0932dc86b8fbee695754a288adece46702446b22" alt=""