南京邮电大学数学实验A 作业3 编程与作图 答案 | 《MATLAB数学实验》第三版 第二章 课后习题答案

若要获得更好的阅读体验,请前往 链接

1(课本习题2)

求满足 ∑ n = 0 m ln ⁡ ( 1 + n ) > 100 \sum_{n = 0}^{m}{\ln{(1 + n)}} > 100 n=0mln(1+n)>100的m最小值.

代码:

s=log(1);n=0;
while s<=100n=n+1;s=s+log(1+n);
end
fprintf("最小m值是%d",n)

输出:

最小m值是37

2(课本习题6)

做出下列函数图像:

(1)曲线 y = x 2 sin ⁡ ( x 2 − x − 2 ) y = x^{2}\sin{(x^{2} - x - 2)} y=x2sin(x2x2), − 2 ≤ x ≤ 2 - 2 \leq x \leq 2 2x2
(分别使用plot和fplot完成);

使用plot完成:

x=-2:0.1:2;y=x.^2.*sin(x.^2-x-2);
plot(x,y)

使用fplot完成:

f = @(x) x.^2 .* sin(x.^2 - x - 2);
fplot(f, [-2, 2])

绘图结果:

image-20240416175409393

(2) 椭圆 x 2 4 + y 2 9 = 1 \frac{x^{2}}{4} + \frac{y^{2}}{9} = 1 4x2+9y2=1;

代码和输出:

r=-pi:0.1:pi;x=2*cos(r);y=3*sin(r);
plot(x,y)

image-20240416175511591

(3) 抛物面 z = x 2 + y 2 z = x^{2} + y^{2} z=x2+y2, ∣ x ∣ < 3 , ∣ y ∣ < 3 |x| < 3,\ |y| < 3 x<3, y<3;

代码和输出:

xa=-3:0.1:3;ya=-3:0.1:3;
[x,y]=meshgrid(xa,ya);
z=x.^2+y.^2;
surf(x,y,z);

image-20240416175524861

(4) 曲面 z = x 4 + 3 x 2 + y 2 − 2 x − 2 y − 2 x 2 y + 6 z = x^{4} + 3x^{2} + y^{2} - 2x - 2y - 2x^{2}y + 6 z=x4+3x2+y22x2y2x2y+6, ∣ x ∣ < 3 |x| < 3 x<3, − 3 < y < 13 - 3 < y < 13 3<y<13;

代码和输出:

xa=linspace(-3,3,100);ya=linspace(-3,13,100);
[x,y]=meshgrid(xa,ya);
z=x.^4+3*x.^2+y.^2-2*x-2*y-2*x.^2.*y+6;
surf(x,y,z);

image-20240416175537235

(5) 空间曲线 x = sin ⁡ t , x = \sin t, x=sint, y = cos ⁡ t y = \cos t y=cost, z = cos ⁡ 2 t z = \cos{2t} z=cos2t, 0 < t < 2 π 0 < t < 2\pi 0<t<2π;

代码和输出:

t=linspace(0,2,50);
x=sin(t);y=cos(t);z=cos(2*t);
plot3(x,y,z)

image-20240416175550081

(6)
半球面 x = 2 sin ⁡ ϕ cos ⁡ θ , y = 2 sin ⁡ ϕ sin ⁡ θ , z = 2 cos ⁡ ϕ x = 2\sin\phi\cos\theta,\ y = 2\sin\phi\sin\theta,\ z = 2\cos\phi x=2sinϕcosθ, y=2sinϕsinθ, z=2cosϕ, 0 ≤ θ ≤ 36 0 o 0 \leq \theta \leq 360^{o} 0θ360o, 0 ≤ ϕ ≤ 9 0 o 0 \leq \phi \leq 90^{o} 0ϕ90o;

代码和输出:

a=linspace(0,2*pi,50);b=linspace(0,pi/2,50);
[a,b]=meshgrid(a,b);
x=2*sin(a).*cos(b);y=2*sin(a).*sin(b);z=2*cos(a);
surf(x,y,z)

image-20240416175603288

(7)
三条曲线合成图 y 1 = sin ⁡ x , y 2 = sin ⁡ x sin ⁡ 10 x , y 3 = − sin ⁡ x y_{1} = \sin x,\ y_{2} = \sin x\sin{10x},\ y_{3} = - \sin x y1=sinx, y2=sinxsin10x, y3=sinx, 0 < x < π 0 < x < \pi 0<x<π.

代码和输出:

x=linspace(0,pi,50);y1=sin(x);
plot(x,y1);
hold on;
y2=sin(x).*sin(10*x);
plot(x,y2);
y3=-sin(x);
plot(x,y3);
hold off;

image-20240416175618749

3

f ( x ) = { x 2 , x ≥ 2 , x + 2 , x < 2 , f(x)=\left\{\begin{matrix}x^2,&x\geq2,\\ x+2,&x<2,\end{matrix}\right. f(x)={x2,x+2,x2,x<2, f ( 2 ) f(2) f(2), f ( − 2 ) f( - 2) f(2).

代码:

function y = g(x)if x >= 2y = x^2;elsey = x + 2;end
endg2 = g(2);
g_minus_2 = g(-2);disp(['g(2) = ', num2str(g2)])
disp(['g(-2) = ', num2str(g_minus_2)])

结果:

g(2) = 4

g(-2) = 0

4

用循环语句计算10!

代码:

sum = 1;
for i = 1:10sum = sum * i;
end
disp(sum)

输出:

3628800

5. 使用两种方法求自然数1~100之和(使用循环和不使用循环)。

使用循环:

sum = 0;
for i = 1:100sum = sum + i;
end
disp(sum)

不使用循环:

clear
sum = sum(1:100);
disp(sum)

结果:

5050

6

某种电子产品使用寿命t (2000)与产品等级s间的对应关系如下表,使用swith判断测试产品的等级。

使用寿命t/ht>=15001200<=t<=15001000<=t<=1200t<1000
产品等级s一等品二等品三等品不合格

代码:

n = input('请输入该电子产品的使用寿命:');if n < 0disp('输入非法!')
elseswitch ncase num2cell(0:1000)disp('不合格')case num2cell(1000:1200)disp('三等品')case num2cell(1200:1500)disp('二等品')otherwisedisp('一等品')end
end

输出:

请输入该电子产品的使用寿命:2000

一等品

7

判断下面语句的运算结果。

(1) 4 < 20 (2) 4 <= 20 (3) 4 == 20 (4) 4 ~= 20

答:(1)真;(2)真;(3)假;(4)真;

8

在MATLAB中使用一个循环确定:如果用户最初在一个银行帐户中存储$10000,并且在每年的年终再存储$10000(银行每年支付6%的利息),那么账户上要积累$1000000要需要多长时间。

代码:

k=1;Sum=1000;
while Sum<1000000Sum=Sum*(1+0.06)+10000;k=k+1;
end
fprintf("需要%d年",k);

输出:

需要35年

9

用matlab创建一个结构体,用于统计学生的情况,包括学生的姓名、学号、各科成绩等。然后使用该结构体对一个班级的学生成绩进行管理,计算总分、平均分。假设学生人数为m=randi([30,
60]).

代码:

% 随机生成学生人数
m = randi([30, 60]);
% 创建班级
class = struct();% 填充学生信息和成绩
for i = 1:mclass(i).name = ['Student ' num2str(i)];class(i).id = i;class(i).grades = randi([30, 100], 1, 5);  % 假设每个学生有5门课程
endfor i = 1:mtotal_score = sum(class(i).grades);average_score = total_score/5;fprintf('学生 %s 的总分是 %d,平均分是 %.2f\n', class(i).name, total_score, average_score);
end

输出:

学生 Student 1 的总分是 371,平均分是 74.20

学生 Student 2 的总分是 303,平均分是 60.60

学生 Student 45 的总分是 254,平均分是 50.80

学生 Student 46 的总分是 421,平均分是 84.20

10

请编程计算 r = s 2 + s 4 + s 6 + s 8 + ⋯ + s 36 + s 38 r = s^{2} + s^{4} + s^{6} + s^{8} + \cdots + s^{36} + s^{38} r=s2+s4+s6+s8++s36+s38,
s=0.5.

代码:

s = 0.5;
r = 0;
for n = 2:2:38r = r + s^n;
end
r

输出:

r = 0.3333

11

用曲面表示函数 z = x 3 + y 3 z = x^{3} + y^{3} z=x3+y3

(1) 使用 ezsurf 函数画。 (2)不使用ezsurf 函数画。

答:

(1)代码:

% 定义函数
f = @(x,y) x.^3 + y.^3;
% 使用ezsurf函数绘制图形
ezsurf(f, [-10 10 -10 10])

输出:

image-20240416175657384

(2)代码:

% 定义x和y的范围
x = -10:0.5:10; y = -10:0.5:10;
% 使用meshgrid函数生成网格点
[X,Y] = meshgrid(x, y);
% 计算每个网格点的z值
Z = X.^3 + Y.^3;
% 使用surf函数绘制图形
surf(X,Y,Z)

image-20240416175706249

12

绘制 z = cos ⁡ x sin ⁡ y y z = \frac{\cos x\sin y}{y} z=ycosxsiny的完整光滑曲面。其中,x ∈ \in [-2π,2π],y ∈ \in [-2π,2π]。(不能使用ezsurf,ezmesh)。

代码:

% 定义x,y的范围
x = linspace(-2*pi, 2*pi, 100);
y = linspace(-2*pi, 2*pi, 100);
% 创建网格
[X, Y] = meshgrid(x, y);
% 计算Z的值,注意在y=0处进行除数异常处理
Z = (cos(X).*sin(Y))./(Y + (Y==0));
% 绘制曲面
surf(X, Y, Z);
xlabel('x');
ylabel('y');
zlabel('z');
str = 'Surface plot of $$ z = \frac{cos(x)sin(y)}{y} $$';
title(str,'Interpreter','latex')

image-20240416175723080

13

在 0≤x≤2π 区间内,分别用红色虚线和蓝色实线绘制曲线 y 1 = 2 e − 0.5 x y1=2e^{- 0.5x} y1=2e0.5x和y2=cos(4πx),给图形加上图例"Y1",“Y2”,,在坐标为(0.8,1.5)处为y1 曲线加上文本说明"曲线 y1=2e^{-0.5x})“;在坐标为(2.5,1.1)处为曲线y2加上文本说明"曲线 y2=cos(4{\pi}x))”; 对x、y轴加上标签"Variable X",“Variable y”.

代码:

% 定义x的范围
x = linspace(0, 2*pi, 100);
% 计算y1和y2的值
y1 = 2*exp(-0.5*x);
y2 = cos(4*pi*x);plot(x, y1, 'r--', 'DisplayName', 'Y1')
hold on
plot(x, y2, 'b-', 'DisplayName', 'Y2')% 添加图例
legend
text(0.8, 1.5, '曲线 y1=2e^{-0.5x}')
text(2.5, 1.1, '曲线 y2=cos(4{\pi}x)')
xlabel('Variable X')
ylabel('Variable Y')hold off

输出:

image-20240416175736310

14

在同一平面中的两个窗口分别画出心形线 { x = a ( 1 − cos ⁡ θ ) cos ⁡ θ y = a ( 1 − cos ⁡ θ ) sin ⁡ θ \left\{\begin{aligned}x&=a(1-\cos\theta)\cos\theta\\y&=a(1-\cos\theta)\sin\theta\end{aligned}\right. {xy=a(1cosθ)cosθ=a(1cosθ)sinθ和马鞍面 x 2 a 2 − y 2 b 2 = 2 z \frac{x^{2}}{a^{2}} - \frac{y^{2}}{b^{2}} = 2z a2x2b2y2=2z,其中,a取学号末尾数字,b取1到10之间的随机整数。

代码:

theta = linspace(0, 2*pi, 1000); % 定义θ的范围
a = 3; % 取学号末尾数字
x = a * (1 - cos(theta)) .* cos(theta); % 计算x的值
y = a * (1 - cos(theta)) .* sin(theta); % 计算y的值figure(1); % 创建新的图形窗口   
plot(x, y); % 在图形窗口中绘制心形线
title('心形线'); % 给图形添加标题[x, y] = meshgrid(-2:0.1:2, -2:0.1:2); % 定义x和y的范围
b = randi([1, 10]); % 取1到10之间的随机整数
z = (x.^2/a^2 - y.^2/b^2)/2; % 计算z的值figure(2); % 创建新的图形窗口
surf(x, y, z); % 在图形窗口中绘制马鞍面
title('马鞍面'); % 给图形添加标题

输出:

image-20240416175749315

image-20240416175759049

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2979230.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

实用电路图轻松掌握,一通百通 | 百能云芯

通过以下各种各样的实用电路&#xff0c;大家可以了解元器件的结构、特性、动作原理及电路的基本控制方式&#xff0c;掌握一些控制规律&#xff0c;这样的话&#xff0c;在日后的电路识图中就能融会贯通&#xff0c;一通百通。 文章中的电路图有难有易&#xff0c;有些图现在…

HF区块链链码基础

链码生命周期 一 . 链码准备 准备文件 . 在测试目录下创建chaincode,拷贝测试链码进 chaincode目录,拷贝 set-env.sh 脚本进 scripts 目录 二. 打包链码 打包测试链码 export FABRIC_CFG_PATH${PWD}/config peer lifecycle chaincode package ./chaincode/chaincode_basic.…

C语言字符串函数库全解!一篇文章大彻大悟醍醐灌顶!

目录 1.字符分类函数 2.字符转换函数 3.strlen的使用和模拟实现 4.strcpy的使用和模拟实现 5.strcat的使用和模拟实现 6.strcmp的使用方法及模拟实现 7.strncpy函数的使用与模拟实现 8.strncat函数的使用方法以及模拟实现 9.strncmp函数的介绍 10.strstr的使用和模拟实…

springboot整合mybatis-puls登陆注册

目录 创建springboot项目 目录结构&#xff1a; 启动类 测试类 idea建表 pom文件 编写yml文件 qq邮箱设置 登陆注册代码 编写持久层(Dao) 注册代码 业务层 业务实现类 mapper 控制层 前端代码 注册页面 邮件正文&#xff1a; 登录代码 控制层 业务层&#…

前端开发攻略---实现发送手机验证码60s倒计时效果(手机号验证+按钮文字自定义显示+Vue2写法+Vue3写法)

1、演示 2、说明 1、为了便于演示&#xff0c;本示例将在3秒后就再次发送。您可以根据需要自定义此时间间隔。 2、采用最少的变量以满足需求&#xff0c;以减少内存占用。 3、不仅仅局限于按钮情况&#xff0c;也可应用于不禁用按钮的情况&#xff0c;以实现更多的扩展性。 4、…

FPGA组合逻辑电路设计之译码器

在数字电路中可以根据电路功能的不同分为&#xff0c;组合逻辑电路与时序逻辑电路。组合逻辑 电路在逻辑功能上的特点是任意时刻的输出仅仅取决于该时刻的输入&#xff0c;与电路原来的状态无 关。而时序逻辑从电路特征上看来&#xff0c;其特点为任意时刻的输出不仅取决于该…

安卓NetworkStatsManager使用及demo

目录 一、TrafficStats类简介二、demo示例 一、TrafficStats类简介 TrafficStats Android API 8提供了android.net.TrafficStats类。 通过此类能获取设备重启以来网络信息&#xff0c;部分函数如下所示&#xff1a; static long getMobileRxBytes() //获取通过移动数据网络…

【SpringBoot】-MyBatis详解+单表操作

作者&#xff1a;学Java的冬瓜 博客主页&#xff1a;☀冬瓜的主页&#x1f319; 专栏&#xff1a;【Framework】 主要内容&#xff1a;什么是MyBatis框架&#xff1f;MyBatis框架有什么用&#xff1f;MyBatis实现查询步骤详解。MyBatis实现单表的增删查改。MyBatis模糊查询&…

TDSQL手动调整备份节点或冷备节点

一、背景描述 近期TDSQL数据库备份不稳定&#xff0c;有些set实例的备份任务未自动发起。经排查分析&#xff0c;存在多个set实例容量已经超过TB级别&#xff0c;且冷备节点都是同一台。因此&#xff0c;需要手动将当前备份节点改到其他备节点&#xff0c;开启增量备份&#x…

FLStudio怎么冻结轨道以及如何批量复制音符

FLStudio是一款功能强大的音乐制作软件&#xff0c;广泛用于音乐制作和打谱当中。我们在制作音乐时&#xff0c;经常会遇到处理大量音频轨道的情况&#xff0c;过多的音频轨道可能会导致电脑性能受限&#xff0c;从而影响工作流程。为了应对这个问题&#xff0c;FLStudio提供了…

CPPTest实例分析(C++ Test)

1 概述 CppTest是一个可移植、功能强大但简单的单元测试框架&#xff0c;用于处理C中的自动化测试。重点在于可用性和可扩展性。支持多种输出格式&#xff0c;并且可以轻松添加新的输出格式。 CppTest下载地址&#xff1a;下载地址1  下载地址2 下面结合实例分析下CppTest如…

小样本学习登Nature!计算效率高170倍,彻底起飞

中科院新提出的社会行为图谱SBeA登上Nature子刊&#xff01; SBeA是一个用于多动物3D姿势估计、身份识别和社会行为分类的小样本学习框架&#xff0c;能够全面量化自由群居动物的行为&#xff0c;使用较少的标记帧数&#xff08;约 400 帧&#xff09;进行多动物三维姿态估计。…

linux常用非基础命令/操作

本篇用于总结蒟蒻博主在使用linux系统的过程中会经常用到但老实记不住的一些非基础命令和操作&#xff0c;方便遗忘时查阅 一&#xff0c;关闭指定端口的进程以释放端口 每个端口都有一个守护进程&#xff0c;kill掉这个守护进程就可以释放端口 ①使用命令【netstat -anp | gre…

数据结构|树形结构|并查集

数据结构|并查集 并查集 心有猛虎&#xff0c;细嗅蔷薇。你好朋友&#xff0c;这里是锅巴的C\C学习笔记&#xff0c;常言道&#xff0c;不积跬步无以至千里&#xff0c;希望有朝一日我们积累的滴水可以击穿顽石。 有趣的并查集剧情演绎&#xff1a;【算法与数据结构】—— 并…

045、seq2seq

之——序列生成 杂谈 基于RNN实现&#xff0c;通过RNN生成器不断获取输入&#xff0c;更新隐藏状态&#xff0c;将最后生成的隐藏状态传递给解码器&#xff0c;然后自循环迭代直到输出停止。 正文 1.训练 训练时候解码器使用目标句子不断作为输入&#xff0c;就算解码错了输入…

linux休眠唤醒流程,及示例分析

休眠流程 应用层通过echo mem > /sys/power/state写入休眠状态&#xff0c;给一张大概流程图 这个操作对应在kernel/power/main.c的state这个attr的store操作 static ssize_t state_store(struct kobject *kobj, struct kobj_attribute *attr,const char *buf, size_t n) …

ESP32-Thonny 拍摄图片到SD卡

前言&#xff1a; 代码运行在Thonny 添加main.py到单片机中&#xff1a; 可以先运行一下试试&#xff1a;会输出以下信息&#xff1a; 没有问题的话&#xff08;SD卡挂载成功&#xff0c;摄像头初始化成功&#xff09;运行一次主程序后&#xff0c;闪光灯会闪烁一下。 代码&…

js获取某月往前推一年或半年的年月数组

前言 需求&#xff1a;需要显示某月份往前推一年或者半年的费用情况&#xff0c;显示到柱形图上&#xff0c;后台接口只返回有数据的年份&#xff0c;这就需要前端拿全部月份数组去比对并显示。 开始 上代码&#xff1a; // date:选择的月份,比如:2024-04,//n:半年或者1年,…

PTA 天梯赛 L1-010 比较大小【C++】 L1-011 A-B 【C++ vector动态数组】【Python 字符串replace函数】

L1-010 比较大小 判断顺序很重要 #include<iostream> using namespace std; int main() {int a, b, c;cin >> a >> b >> c;int temp;if (a > b) {temp a;a b;b temp;}if (a > c) {temp a;a c;c temp;}if (b > c) {temp b;b c;c te…

C++ //练习 13.17 分别编写前三题中所描述的numbered和f,验证你是否正确预测了输出结果。

C Primer&#xff08;第5版&#xff09; 练习 13.17 练习 13.17 分别编写前三题中所描述的numbered和f&#xff0c;验证你是否正确预测了输出结果。 环境&#xff1a;Linux Ubuntu&#xff08;云服务器&#xff09; 工具&#xff1a;vim 代码块 /*************************…