java矩阵类_151-矩阵类

[java]代码库import java.util.Scanner;

import java.util.Arrays;

public class Main {

public static void main(String[] args) {

Scanner scan = new Scanner(System.in);

int r = scan.nextInt();

int c = scan.nextInt();

System.out.println("row:"+r+" column:"+c);

//输入,修改矩阵的值

Matrix me = new Matrix(r,c);

for(int i = 0; i < r; i++)

{

for(int j = 0; j < c; j++)

{

double a = scan.nextDouble();

me.set(i, j, a);

}

}

r = scan.nextInt();

c = scan.nextInt();

double a = scan.nextDouble();

me.set(--r, --c, a);

System.out.println("after set value:");

me.show();

//打印具体位置上的值

r = scan.nextInt();

c = scan.nextInt();

System.out.print("value on ("+r+","+c+"):");

System.out.printf("%.0f\n",me.get(--r, --c));

//矩阵相加输出

r = scan.nextInt();

c = scan.nextInt();

Matrix jia = new Matrix(r,c);

for(int i = 0; i < r; i++)

{

for(int j = 0; j < c; j++)

{

a = scan.nextDouble();

jia.set(i, j, a);

}

}

System.out.println("after add:");

(me.add(jia)).show();

//矩阵相乘输出

r = scan.nextInt();

c = scan.nextInt();

Matrix cheng = new Matrix(r,c);

for(int i = 0; i < r; i++)

{

for(int j = 0; j < c; j++)

{

a = scan.nextDouble();

cheng.set(i, j, a);

}

}

System.out.println("after multiply:");

(me.multiply(cheng)).show();

//矩阵转置输出

System.out.println("after transpose:");

(me.transpose()).show();

}

}

class Matrix

{

private int row;//行

private int col;//列

double[][] m;

public Matrix(int a, int b)

{

row = a;

col = b;

m = new double [a][b];

}

void set(int r, int c, double a)

{

m[r][c] = a;

}

double get(int r, int c)

{

return m[r][c];

}

int width()

{

return col;

}

int height()

{

return row;

}

Matrix add(Matrix b)

{

Matrix a = new Matrix(row,col);

for(int i = 0; i < row; i++)

{

for(int j = 0; j < col; j++)

a.set(i,j, b.get(i,j)+this.m[i][j]);

}

return a;

}

Matrix multiply(Matrix b)

{

Matrix a = new Matrix(row,b.width());

for( int i = 0; i < row; i++)

{

for( int j = 0; j < b.width(); j++)

{

int sum = 0;

for( int k = 0; k < col; k++)

sum += this.get(i,k)*b.get(k, j);

a.set(i, j, sum);

}

}

return a;

}

Matrix transpose()

{

Matrix a = new Matrix(col,row);

for(int i = 0; i < col; i++)

{

for(int j = 0; j < row; j++)

a.set(i,j,this.m[j][i]);

}

return a;

}

void show()

{

for(int i = 0; i < row; i++)

{

for(int j = 0; j < col; j++)

{

if( j == 0)

System.out.printf("%.0f",this.get(i, j));

else

System.out.printf(" %.0f",this.get(i, j));

}

System.out.println();

}

}

}

694748ed64b9390909c0d88230893790.png

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

刻画小狗状态java_JAVA面向接口编程

JAVA面向接口编程小狗在不同环境条件下可能呈现不同的状态&#xff0c;小狗通过调用 cry()方法体现自己的当前的状 态。要求用接口封装小狗的状态。具体要求如下。• 编写一个接口 DogState&#xff0c;该接口有一个名字为 void showState()的方法。• 编写 Dog 类&#xff0c;…

php 图片合成,PHP中多张图片合成一张图片例子

今天分享一段PHP中多张图片合成一张图片的代码实现&#xff0c;我们可以在图片合成&#xff0c;水印&#xff0c;九宫格等需求下使用到类似这样的图片合成效果,下面一起来看看例子吧。今天分享一段PHP中多张图片合成一张图片的代码实现&#xff0c;我们可以在图片合成&#xff…

php的cms是什么意思,phpcms是什么

phpcms是一款具备文章、下载、图片、分类信息、影视、商城、采集、财务等众多功能的强大、易用、可扩展的优秀网站管理软件&#xff1b;该软件采用模块化开发&#xff0c;支持多种分类方式&#xff0c;使其可方便实现个性化网站的设计、开发与维护。phpcms是一款具备文章、下载…

边缘检测滤波matlab,卷积滤波器与边缘检测

频率&#xff1a;对于声音&#xff0c;频率实际上是指声波振荡的速度高低频率高频图像是强度变化很大的图像。并且亮度级别从一个像素到下一个像素快速变化。低频图像可以是亮度相对均匀或变化非常慢的图像。这是一个例子中最容易看到的。大多数图像都有高频和低频成分。在上图…

php 读取 stl 文件,科学网—[转载]【源码】读取ASCII STL文件的STLReader - 刘春静的博文...

读取包含顶点和面的ASCII STL文件&#xff0c;并将其构造为矩阵“顶点”、“颜色”和“面”。之后&#xff0c;使用各小模块在Matlab上建立模型。Read ASCII STL file which contains vertexes and faces and structure it to matrixes "vertexes", "colors&quo…

dsm php,docker dsm是什么?

docker dsm是什么&#xff1f;docker dsm是&#xff1a;从DSM6.0开始如果装了docker的话可以看到下面的图&#xff1a;上图可以看到创建了一个新的DSM&#xff0c;名字为DDSM1&#xff0c;经试验功能和正式DSM一模一样。同时白裙一样可以QuickConnect。然后用Putty登录上去&…

php 5.6 文档,文件存储 | 进阶系列 | Laravel 5.6 中文文档

文件存储由 学院君 创建于3年前, 最后更新于 1年前版本号 #231608 views3 likes0 collects简介Laravel 基于 Frank de Jonge 开发的 PHP 包 Flysystem 提供了强大的文件系统抽象层。Laravel 集成 Flysystem 以便使用不同驱动简化对文件系统的操作&#xff0c;这些驱动包括本地文…

阐述oracle的体系结构,Oracle数据库逻辑体系结构详解

以前对Oracle数据库的了解大多数是集中在mysql&#xff0c;最近工作里面一直使用的是Oracle&#xff0c;虽然说在互联网行业mysql大行其道&#xff0c;但是一些传统行业或者是金融领域还是更加倾向于使用oracle&#xff0c;sqlserver这种大型数据库。为此还是有必要深入了解以下…

linux解锁文件.user.ini,Linux下解决网页服务器权限和.user.ini无法删除的问题

解决网页服务器权限问题在linux环境下搭建Nginx/apache网页服务器&#xff0c;在尝试访问页面时都会遇到这个问题&#xff0c;提示没有写入权限&#xff0c;或者必须访问网页服务器权限。这源自于linux对于权限的限制比较严格。所以网上无数的解决方法&#xff0c;无外乎一个提…

linux内核 lts长期演进,Linux Kernel 4.19 和 5.4 生命周期延长至 6 年

近日&#xff0c;Linux 内核开发及维护者 Greg Kroah-Hartman 宣布将 Linux 内核 4.19 和 5.4 版本的生命周期终止(EOL)支持从两年延长到六年&#xff0c;分别延长至 2024 和 2025 年。在这期间&#xff0c;它们能够继续向后移植 bug 并获得一些重要的安全修复程序。Linux 内核…

linux如何运行qt源码,Linux/Ubuntu下编译Qt4.8.2源码

本人所用的系统为Ubuntu 14&#xff0c;所下载的QT源码版本为4.8.2。以下是编译QT源码的基本步骤&#xff1a;2&#xff0e;解压代码输入指令&#xff1a; tar zxvf qt-everywhere-opensource-src-4.8.2.tar.gz&#xff0c;解压出QT源代码。3&#xff0e;执行./config生成makef…

linux启动过程中内核拷贝,轻松识破linux内核启动过程中的“”套路“”

内核启动流程相关的内容让很多热爱linux的小伙伴既爱又恨&#xff0c;因为这是了解linux系统基本构造的良好过程同时由于其本身复杂且底层&#xff0c;脑子中的脉络不是很清晰&#xff0c;本文就总结了一些优秀博文&#xff0c;以自己的理解来解构一下。本文的环境是CentOS 6.8…

linux wifi ip,Linux环境下使用WIFI模块:使用DHCP工具动态获得IP地址

使用DHCP工具动态获得IP地址实验版本及下载地址DHCP&#xff1a;dhcp-4.4.1.tar.gz链接: [https://www.isc.org/downloads/]编译安装DHCP配置编译选项解压完成后进入DHCP根文件目录&#xff0c;输入配置指令./configure --hostarm-linux ac_cv_file__dev_randomyes --with-rand…

linux创建a1的硬链接a2,Linux命令-重定向和软硬链接

echo功能说明&#xff1a;显示文字. 语 法&#xff1a;echo [-ne][字符串] 或 echo [–help][–version]参数&#xff1a;   -n 不要在最后自动换行重定向>是定向输出到文件&#xff0c;如果文件不存在&#xff0c;就创建文件&#xff1b;如果文件存在&#xff0c;就将其…

linux shell 博客,【博客侠】Linux Shell脚本系列:开始上手(1)

看标题大家应该知道&#xff0c;这是一个关于 Linux Shell 脚本的系列文章。通过本系列文章希望帮助 Linux 初学用户快速开始上手编写 Shell 脚本&#xff0c;能够利索的对脚本进行测试和使用。在接下来的首篇文章中&#xff0c;我们将介绍什么是 Shell&#xff0c;有哪些 Linu…

sql server linux性能,详细了解SQL Server 2008性能和性能优化

在SQL Server 2005或更早的版本中的中&#xff0c;表变量是不能作为存储过程的参数的。当多行数据到SQL Server需要发送多行数据到SQL Server &#xff0c;开发者要么每次发送一列记录&#xff0c;或想出其他的变通方法&#xff0c;以满足需求。虽然在.net 2.0中提供了个SQLBul…

开发linux显卡驱动,显卡驱动开发DRM入门--Apple的学习笔记

由于之前的blog提及kmscube的源码我没有找到&#xff0c;所以只能在网上搜索了。DRM简介DRM是Linux目前主流的图形显示框架&#xff0c;同时DRM可以统一管理GPU和Display驱动&#xff0c;使得软件架构更为统一&#xff0c;方便管理和维护。而且drm是集成在linux kernel中的。DR…

android mvc使用方法,详细学习android mvc设计模式教程

MVC 是一种使用 MVC(Model View Controller 模型-视图-控制器)设计创建 web 应用程序的模式。其分层有助于管理复杂的应用程序&#xff0c;因为可以在一个时间内专门关注一个方面。例如&#xff0c;可以在不依赖业务逻辑的情况下专注于视图设计。同时也让应用程序的测试更加容易…

android l 电池,DIY新技能--M1L换电池

DIY新技能--M1L换电池2019-10-23 16:48:526点赞6收藏10评论更换理由M1L是好几年前买的了&#xff0c;具体几年前我都懒得购买记录了。前前后后买了4台锤子手机了&#xff0c;这是我支持老罗的第二款手机&#xff0c;前一款是坚果手机&#xff0c;买了两台早先给妈妈用一台后来给…

android版本10好不好,一加正式推送Android 10系统 流畅性怎么样

近日&#xff0c;一加正式推送Android 10系统&#xff0c;不知道流畅性如何呢&#xff1f;一加官方推特正式宣布Android 10系统已进行阶段性推送&#xff0c;从今天开始一加7和一加7 Pro手机用户将会陆续收到氧OS系统的更新&#xff0c;国内基于Android 10的氢OS将于下月推送。…