#include "iostream" using namespace std; class Matrix { private: double** A; //矩阵A double *b; //向量b public: int size; Matrix(int ); ~Matrix(); friend double* Dooli(Matrix& ); void Input(); void Disp(); }; Matrix::Matrix(int x) { size=x; //为向量b分配空间并初始化为0 b=new double [x]; for(int j=0;j<x;j++) b[j]=0; //为向量A分配空间并初始化为0 A=new double* [x]; for(int i=0;i<x;i++) A[i]=new double [x]; for(int m=0;m<x;m++) for(int n=0;n<x;n++) A[m][n]=0; } Matrix::~Matrix() { cout<<"正在析构中~~~~"<<endl; delete b; for(int i=0;i<size;i++) delete A[i]; delete A; } void Matrix::Disp() { for(int i=0;i<size;i++) { for(int j=0;j<size;j++) cout<<A[i][j]<<" "; cout<<endl; } } void Matrix::Input() { cout<<"请输入A:"<<endl; for(int i=0;i<size;i++) for(int j=0;j<size;j++){ cout<<"第"<<i+1<<"行"<<"第"<<j+1<<"列:"<<endl; cin>>A[i][j]; } cout<<"请输入b:"<<endl; for(int j=0;j<size;j++){ cout<<"第"<<j+1<<"个:"<<endl; cin>>b[j]; } } double* Dooli(Matrix& A) { double *Xn=new double [A.size]; Matrix L(A.size),U(A.size); //分别求得U,L的第一行与第一列 for(int i=0;i<A.size;i++) U.A[0][i]=A.A[0][i]; for(int j=1;j<A.size;j++) L.A[j][0]=A.A[j][0]/U.A[0][0]; //分别求得U,L的第r行,第r列 double temp1=0,temp2=0; for(int r=1;r<A.size;r++){ //U for(int i=r;i<A.size;i++){ for(int k=0;k<r-1;k++) temp1=temp1+L.A[r][k]*U.A[k][i]; U.A[r][i]=A.A[r][i]-temp1; } //L for(int i=r+1;i<A.size;i++){ for(int k=0;k<r-1;k++) temp2=temp2+L.A[i][k]*U.A[k][r]; L.A[i][r]=(A.A[i][r]-temp2)/U.A[r][r]; } } cout<<"计算U得:"<<endl; U.Disp(); cout<<"计算L的:"<<endl; L.Disp(); double *Y=new double [A.size]; Y[0]=A.b[0]; for(int i=1;i<A.size;i++ ){ double temp3=0; for(int k=0;k<i-1;k++) temp3=temp3+L.A[i][k]*Y[k]; Y[i]=A.b[i]-temp3; } Xn[A.size-1]=Y[A.size-1]/U.A[A.size-1][A.size-1]; for(int i=A.size-1;i>=0;i--){ double temp4=0; for(int k=i+1;k<A.size;k++) temp4=temp4+U.A[i][k]*Xn[k]; Xn[i]=(Y[i]-temp4)/U.A[i][i]; } return Xn; } int main() { Matrix B(4); B.Input(); double *X; X=Dooli(B); cout<<"~~~~解得:"<<endl; for(int i=0;i<B.size;i++) cout<<"X["<<i<<"]:"<<X[i]<<" "; cout<<endl<<"呵呵呵呵呵"; return 0; }
标签: 道理特分解法
上传时间: 2018-05-20
上传用户:Aa123456789
FC162是一款低功耗,高速,高噪声容限,EPROM/ROM基于8位CMOS工艺制造的单片机,采用RISC指令集,共有42条指令, 除分支指令为两个周期指令以外其余为单周期指令。这种易用、易记的指令集大大缩短了开发时间。 FC162包含了上电复位(Power-on Reset POR),掉电复位(Brown-out Reset BOR), 上电复位计数器(Power-up Reset Timer PWRT),振荡启动计数器 (Oscillator Start-up Timer OST), 看门狗定时器(Watchdog Timer), EPROM/ROM, SRAM,双向三 态I/O口,(可以设置为上拉/下拉), 省电睡眠模式, 一个带8位预置器的8位定时/计数器,独立中断,睡眠唤醒模式和可靠的代码保 护,有两个振荡源可供用户配置选择,包含省电振荡源和低功耗振荡器。 FC162可访问256×13的程序存储空间。 FC162能直接或间接访问寄存器以及数据存储区,所有的特殊功能寄存器分布在数据存储区同时包含特定的程序指针。
标签: fc162
上传时间: 2021-11-13
上传用户:qingfengchizhu
LabView实用技巧系列视频 -LabVIEW2009-2010破解工具 -LabView资料.zip 116.4MLabVIEW与机器人科技创新活动.zip 1.63GLabVIEW高级程序设计.zip 335.1MLabVIEW高级编程与虚拟仪器工程应用.zip 122.2MLabView宝典.zip 1.02GLabVIEW8.6中文版讲解视频(无声音).rar 264.9MLabVIEW2010.rar 863.7MLabVIEW 程序设计基础与提高.zip 544.5M清华版labview教程12.25.rar 1MVB6_OPC_Client.rar 17KB9.VI的可重入性.avi 68.5M8.控件的输入与输出转换.avi 55.2M7.VI本地化.avi 72.2M6.条件结构的巧用.avi 133.6M5.数组和簇.avi 131.1M4.程序结构中的分支结构和顺序结构.avi 69.8M3.程序结构中的循环结构.avi 88.2M23.制作不规则图形的子VI图标.avi 52.7M22.界面设计技巧2.avi 57.6M21.界面设计技巧1.avi 86.3M20.用户界面设计5.avi 71.4M2.多态VI的创建.avi 82.8M19.用户界面设计4.avi 41.3M18.用户界面设计3.avi 51.2M17.用户界面设计2.avi 56.3M16.用户界面设计1.avi 36.1M15.波形图表、波形图和XY图表.avi 63.5M14.列表框控件添加图标.avi 84.9M13.在文件夹下直接创建新的VI.avi 72.5M12.控件板和函数板的使用.avi 80.5M11.自定义控件.avi 44.2M10.VI属性(下).avi 95.7M10.VI属性(上).avi 85.3M1.VI的创建.avi 68.3M
上传时间: 2022-06-14
上传用户:
AT89C52是美国ATMEL,公司生产的低电压,高性能CMOS 8位单片机,片内含8k bytes的可反复擦写的Flash只读程序存储器和256 bytes的随机存取数据存储器(RAM),器件采用ATMEL公司的高密度、非易失性存储技术生产,与标准MCS-51指令系统及8052产品引脚兼容,片内置通用8位中央处理器(CPU)和Flash存储单元,功能强大AT89C52单片机适合于许多较为复杂控制应用场合主要性能参数:·与MCS-51产品指令和引脚完全兼容.8k字节可重擦写Flash闪速存储器.1000次擦写周期静态操作:OHz-24MHz·三级加密程序存储器•256х8 hA部RAM•32编程1/0口线.3个16位定时/计数器•8个中断源·程串行UART通道低功耗空闲和掉电模式·PO口:P0口是一组8位漏极开路型双向1/0口,也即地址/数据总线复用口。作为输出口用时,每位能吸收电流的方式驱动8个TTL逻辑门电路,对端口P0写"1"时,可作为高阻抗输入端用.在访问外部数据存储器或程序存储器时,这组口线分时转换地址(低8位)和数据总线复用,在访问期间滋活内部上拉电阻.在Flash编程时,PO口接收指令字节,而在程序校验时,输出指令字节,校验时,要求外接上拉电阻。
标签: at89c52
上传时间: 2022-06-19
上传用户:
本章首先介绍论文的研究背景,先介绍无线Mesh网络,提出无线Mesh网络的特点与应用场景,然后从网络管理技术发展的角度,引出无线Mesh网络的管理技术。接着分析无线Mesh网络系统的研究现状,从无线Mesh网络的组网技术发展到相应的管理技术的发展。通过分析现阶段的发展瓶颈,引出论文的研究内容和创新点。最后介绍论文的组织结构安排。1.1研究背景1.1.1无线Mesh网技术无线Mesh网络(Wireless Mesh Network,WMN)7是一种新型动态自组织自配置的无线网络,它结合了无线局域网与移动自组网的特点,支持宽带和高速多媒体业务,近年来得到越来越多的重视和发展。它具有不同于传统网络的特点,在提高网络覆盖率、增加网络容量、减少前期投资方面具有很大优势。网络中的节点能够自动地建立无线多跳网络,被称为廉价的“最后一公里”宽带接入方案.在传统的无线局域网中,客户端通过AP(Access Point)接入点,利用无线链路来访问网络,这样形成的接入关系叫BSS(Basic Service Set)用户相互通信依赖于这个固定的接入点AP,这样的网络是一种单跳的网络.而在无线Mesh网络中,一个Mesh节点既可以提供AP功能,又能提供各节点之间相互连接的功能,每个节点都是一个对等的结构,可以直接进行通信
上传时间: 2022-06-23
上传用户:
CH9329 芯片有 3 串口通信种模式:串口通信模式 0:协议传输模式(默认);串口通信模式 1:ASCII 模式;串口通信模式 2:透传模式。CH9329 芯片默认工作在串口通信模式 0(协议传输模式),本协议主要用于指定 CH9329 芯片工作在该模式下的串口通信协议。任何模式下,芯片检测到该 SET 引脚为低电平后自动切换到“协议传输模式”,客户端串口设备可进行参数配置。因此,需要进行参数配置时,可以先设置 SET 引脚为低电平,然后再进行配置。
上传时间: 2022-07-09
上传用户:xsr1983
可拓学的专家系统,基于B/S结构,动态,网络专家系统.
上传时间: 2016-11-05
上传用户:yuanyuan123
使用的是API编程,可格式化、校验和读写特殊扇区。可用作Windows下的磁盘加密。本函数还有以下两个缺点以待改进: 1.本函数还只能读能读 A: 和 B:,即只能对软盘操作 2.不能改变磁盘扇区大小,只能是标准的 512 个字节。 参数说明: command 操作: 0 重置磁盘 2 读扇区 3 写扇区 4 校验磁道 5 格式化磁道 8 得到设备参数 (int 1EH) drive 驱动器 A:=0 B:=1 head 磁头号,范围 0 - 1 track 磁道号,范围 0 - 84 ( 80 - 84 为特殊磁道,通常用来加密 ) sector 扇区号,范围 0 - 255 ( 19 - 255 为非标准扇区编号,通常用来加密) nsectors 每次读或写的扇区数,不能超出每磁道的最大扇区数 buffer 数据写入或读出的缓冲区,大小为 512 个字节 返回值 ( 同 Int 13H ): 0x0 成功 0x1 无效的命令 0x3 磁盘被写保护 0x4 扇区没有找到 0xa 发现坏扇区 0x80 磁盘没有准备好
上传时间: 2013-12-05
上传用户:moerwang
Floyd-Warshall算法描述 1)适用范围: a)APSP(All Pairs Shortest Paths) b)稠密图效果最佳 c)边权可正可负 2)算法描述: a)初始化:dis[u,v]=w[u,v] b)For k:=1 to n For i:=1 to n For j:=1 to n If dis[i,j]>dis[i,k]+dis[k,j] Then Dis[I,j]:=dis[I,k]+dis[k,j] c)算法结束:dis即为所有点对的最短路径矩阵 3)算法小结:此算法简单有效,由于三重循环结构紧凑,对于稠密图,效率要高于执行|V|次Dijkstra算法。时间复杂度O(n^3)。 考虑下列变形:如(I,j)∈E则dis[I,j]初始为1,else初始为0,这样的Floyd算法最后的最短路径矩阵即成为一个判断I,j是否有通路的矩阵。更简单的,我们可以把dis设成boolean类型,则每次可以用“dis[I,j]:=dis[I,j]or(dis[I,k]and dis[k,j])”来代替算法描述中的蓝色部分,可以更直观地得到I,j的连通情况。
标签: Floyd-Warshall Shortest Pairs Paths
上传时间: 2013-12-01
上传用户:dyctj
超声影像工作站系统可与各种型号的B超、彩超连接,实时采集、显示、处理、存贮超声图像,采用全数字化处理技术,可对各种超声图像进行动态采集
上传时间: 2014-06-01
上传用户:ippler8