「java字母矩阵」java的矩阵运算
今天给各位分享java字母矩阵的知识,其中也会对java的矩阵运算进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
- 1、用java声明Matrix类表示矩阵,使用二维数组存储矩阵元素,实现以下方法:
- 2、java构造一个矩阵
- 3、java如何输入一个自定义矩阵
- 4、c语言或java怎么把字母转换成矩阵
- 5、用JAVA编写矩阵
- 6、java求解:8行8列的矩阵中填入8个字母Q,要求不能在同行同列或任意对角线重复出现,并且是随机不能手动设定
用java声明Matrix类表示矩阵,使用二维数组存储矩阵元素,实现以下方法:
public class Matrix {
private static String matrix_A;
private int mx[][], m, n;
public Matrix(int r, int c) {
m = r;
n = c;
mx = new int[m][n];
iniMatrix();
}
public Matrix() {
m = 3;
n = 3;
mx = new int[3][3];
iniMatrix();
}
public void iniMatrix()// 随机取数
{
int i, j;
for (i = 0; i = m - 1; i++)
for (j = 0; j = n - 1; j++)
mx[i][j] = (int) (Math.random() * 100);
}
public void tranMatrix()// 转置矩阵
{
int i, j, t;
int mt[][] = new int[m][n];
for (i = 0; i = m - 1; i++)
for (j = 0; j = n - 1; j++)
mt[i][j] = mx[i][j];
t = m;
m = n;
n = t;
mx = new int[m][n];
for (i = 0; i = m - 1; i++)
for (j = 0; j = n - 1; j++)
mx[i][j] = mt[j][i];
}
public void printMatrix()// 输出矩阵所有值
{
int i, j;
for (i = 0; i = m - 1; i++) {
for (j = 0; j = n - 1; j++)
System.out.print(" " + mx[i][j]);
System.out.println();
}
}
//判断一个矩阵是否为上三角矩阵
public boolean isUpperTriangularMatrix() {
int i, j = 0;
int c = this.mx[1][0];
for(i=1; ithis.mx.length; i++)
for(j=0; ji; j++)
if(this.mx[i][j] != c)
break;
if(i=this.mx.length)
return true;
return false;
}
public void addMatrix(Matrix b)// 矩阵相加
{
int i, j;
for (i = 0; i = m - 1; i++)
for (j = 0; j = n - 1; j++)
mx[i][j] = mx[i][j] + b.mx[i][j];
}
public static void main(String args[]) {
Matrix ma = new Matrix(4, 3);
Matrix mb = new Matrix(4, 3);
System.out.println("The matrix_A:");
ma.printMatrix();
System.out.println("The matrix_B:");
mb.printMatrix();
if(ma.isUpperTriangularMatrix())
System.out.println("上三角矩阵:\n" + ma.isUpperTriangularMatrix());
System.out.println("Matrix_A + Matrix_B:");
ma.addMatrix(mb);
ma.printMatrix();
System.out.println("Transpose Matrix_A:");
mb.tranMatrix();
mb.printMatrix();
System.out.println("Transpose Matrix_A+Matrix_B:");
mb.tranMatrix();
mb.printMatrix();
}
}
java构造一个矩阵
1、java构造函数--数组 在构造函数中初始化数组,如 public class array { private int [][] matrix; public array(int r,int c) { matrix=new matrix[r][c]; } }
matrix=new matrix[r][c];
2、这里是new int[][]; java中8个基本数据类型都是有默认值的,int默认值为0 ,
3、所以数组中默认都为0.
4、但是切记有默认值的变量必须是类的属性,方法中局部变量必须赋值才可以使用。
java如何输入一个自定义矩阵
java中自定义矩阵:
public static void main(String[] args) {
// TODO Auto-generated method stub
int n= 5;//长度
int array_int[][] = new int[n][n];
//初始化
for(int i=0;in;i++){
for(int j=0;jn;j++){
if(i==0){
if(j%2==0){
array_int[i][j] = (j+1)*(j+1);
}
else{
array_int[i][j] = array_int[i][j-1]+1;
}
}
else if(j==0){
if(i%2==1){
array_int[i][j] = (i+1)*(i+1);
}
else {
array_int[i][j] = array_int[i-1][j]+1;
}
}
else{
if(ij){
if(j%2==0){
array_int[i][j] = array_int[0][j]-i ;
}
else{
array_int[i][j] = array_int[0][j]+i ;
}
}
else{
if(i%2==0){
array_int[i][j] = array_int[i][0]+j ;
}
else{
array_int[i][j] = array_int[i][0]-j ;
}
}
}
//System.out.println(i+" "+j+":"+array_int[i][j] );
}
}
for(int i=0;in;i++){
for(int j=0;jn;j++){
System.out.print(array_int[i][j]+ " " );
}
System.out.println();
}
}
当等于5时的运行结果:
1 2 9 10 25
4 3 8 11 24
5 6 7 12 23
16 15 14 13 22
17 18 19 20 21
c语言或java怎么把字母转换成矩阵
首先要区分代码是几进制的,一般10进制是制作2*10的表格,首位1,虚数前几位也都是代码+1。再就是2进制的,同样制作表格,首位0,虚位全是代码+1。所有进制的末尾都是代码本身。用c++ 6.0就行
用JAVA编写矩阵
public static void main(String[] args) throws Exception {
print(create(getNum()));
}
private static int getNum() {
Scanner scanner = new Scanner(System.in);
int n = 0;
do {
System.out.println("请输入要生成的阶数:");
String input = scanner.next();
if (isDigital(input)) {
n = Integer.parseInt(input);
if (n = 0) {
System.out.println("阶数必须大于0");
}
}
} while (n == 0);
return n;
}
private static int[][] create(int n) {
int[][] num = new int[n][n];
int ax = 1, ay = 0, x = 0, y = 0;
for (int m = 1; m = n * n; m++) {
num[x][y] = m;
int tmpx = x + ax;
int tmpy = y + ay;
if (tmpx = n || tmpx 0 || tmpy = n || tmpy 0 || num[tmpx][tmpy] != 0) {
if (ax == 0) {
ax = -ay;
ay = 0;
} else if (ay == 0) {
ay = ax;
ax = 0;
}
}
x += ax;
y += ay;
}
return num;
}
private static void print(int[][] num) {
int length = String.valueOf(num.length * num.length).length();
for (int i = 0; i num.length; i++) {
for (int j = 0; j num[i].length; j++) {
String tmp = String.valueOf(num[i][j]);
while (tmp.length() length) {
tmp = " " + tmp;
}
System.out.print(tmp + " ");
}
System.out.println();
}
}
private static boolean isDigital(String input) {
if (input == null || input.length() == 0) return false;
for (int i = 0; i input.length(); i++) {
char ch = input.charAt(i);
if (!Character.isDigit(ch)) {
System.out.println("输入的阶数必须为数字");
return false;
}
}
return true;
}
运行时输入要生成的阶数就可以了,比如生成问题上的矩阵输入4就可以了。
java求解:8行8列的矩阵中填入8个字母Q,要求不能在同行同列或任意对角线重复出现,并且是随机不能手动设定
/*
*这是八皇后问题
*用回溯法解决
*输出:1 5 8 6 3 7 2 4
*表示第一行第一列放Q 第二行第五列放Q 依次类推
*输出所有可能的放法
* */
public class NQueens {
private int X[];//创建一个数组,数组中元素X[i]表示第i行第X[i]列放Q
/*
*检查k行是否能放一个Q
*@param k
*第k行
*@return
* */
public boolean place(int k){
int i=1;
while(ik){
//不能同列且不能在一条对角线上
if( (X[i]==X[k]) || (Math.abs((X[i]-X[k]))==Math.abs(i-k))){
return false;
}
i++;
}
return true;
}
/*
*输出数组
**/
public void outPut(){
for(int i=1;iX.length;i++){
System.out.print(X[i]+" ");
}
System.out.println();
}
/*
*回溯法
*@param n
*n表示几行几列
* */
public void start(int n){
int k=1;
while(k0){
X[k]=X[k]+1;
while(X[k]=n !place(k)){
X[k]=X[k]+1;
}
if(X[k]=n){
//输出所有可能结果
if(k==n){
outPut();
}
else {
k++;
X[k]=0;
}
}else{
k--;
}
}
}
/*
*构造方法
*@param n
*n表示矩阵行数 初始化数组
* */
public NQueens(int n){
X=new int[n+1];
start(n);
}
public static void main(String []args){
new NQueens(8);
}
}
java字母矩阵的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java的矩阵运算、java字母矩阵的信息别忘了在本站进行查找喔。