首页 > 编程知识 正文

java矩阵旋转代码(数字旋转方阵java)

时间:2023-12-20 12:40:59 阅读:318363 作者:TAMN

本文目录一览:

参考下面的代码,用java编程一个回旋(螺旋)矩阵

Java程序:

public class Main {

public static void main(String[] args) {

    int LEN = 8;

    int[][] arr = new int[LEN][LEN];

    int i = 0, j = 0;

    int n = 1;

    

    arr[i][j] = n;

    while(n  LEN * LEN) {

     while(j+1LEN  arr[i][j+1]==0){

     j++;

     arr[i][j] = ++n;

     }

     while(i+1LEN  arr[i+1][j]==0){

     i++;

     arr[i][j] = ++n;

     }

     while(j-1=0  arr[i][j-1]==0){

     j--;

     arr[i][j] = ++n;

     }

     while(i-1=0  arr[i-1][j]==0){

     i--;

     arr[i][j] = ++n;

     }

    }

    

    for(i=0; iLEN; i++) {

     for(j=0; jLEN; j++){

     System.out.printf("%4d", arr[i][j]);

     }

     System.out.println();

    }

}

}

运行结果:

   1   2   3   4   5   6   7   8

  28  29  30  31  32  33  34   9

  27  48  49  50  51  52  35  10

  26  47  60  61  62  53  36  11

  25  46  59  64  63  54  37  12

  24  45  58  57  56  55  38  13

  23  44  43  42  41  40  39  14

  22  21  20  19  18  17  16  15

JAVA android 矩阵 怎么设置坐标

1、设置图片位置坐标

matrix.postTranslate(x,y) ——这个(x,y)为图片左上角的位置

2、设置图片图片中心点为中心旋转

matrix.postRotate(角度, x, y);——这个(x,y)为图片中心点的位置

3、渲染图片

canvas.drawBitmap( BIT , matrix , new Paint());

如何用JAVA实现螺旋矩阵

import java.io.*;public class RingDemo {

public static void main(String[] args) {

String strIn = "";

System.out.print("请输入矩阵的行列数:");

InputStreamReader input = new InputStreamReader(System.in);

BufferedReader buff = new BufferedReader(input);

try {

strIn = buff.readLine();

} catch (IOException e) {

System.out.println(e.toString());

}

int int1 = Integer.parseInt(strIn);

int n = int1;

System.out.println("这是行列数为" + n + "的螺线型数组:");

int intA = 1; // 初始化

int[][] array = new int[n][n];

int intB;

if (n % 2 != 0) {

intB = n / 2 + 1; // 奇数时i循环次数

} else

intB = n / 2; // 偶数时i循环次数

for (int i = 0; i intB; i++) { // 从外到里循环

// 从左到右横的开始

for (int j = i; j n - i; j++) {

array[i][j] = intA;

intA++;

}

// 从上到下纵

for (int k = i + 1; k n - i; k++) {

array[k][n - i - 1] = intA;

intA++;

}

// 从右到左横

for (int l = n - i - 2; l = i; l--) {

array[n - i - 1][l] = intA;

intA++;

}

// 从下到上纵

for (int m = n - i - 2; m i; m--) {

array[m][i] = intA;

intA++;

}

}

// 输出数组

for (int i = 0; i n; i++) {

for (int j = 0; j n; j++) {

System.out.print(array[i][j] + " ");

}

System.out.println();

} }

}

java矩阵转置

你的转置意思是 行列交换?

public static Object[][] turnA(Object[][] a){

Object[][] b=new Object[a[0].length][a.length];

for(int i=0;ia.length; i++)

for(int j=0;ja[0].length;j++)

b[j][i]=a[i][j];

return b;

}

这个方法转置的是对象矩阵,因此不能传入基本变量的数组,需要用类型包装器包装。

e.g:

Integer[][] i=new Integer[3][5];

//int[][] i=new int[4][3];

//Can't use here; Integer,Double,String,byte and so on..

Random r=new Random();

for(int j=0;ji.length;j++){

Arrays.fill(i[j], r.nextInt(100));

System.out.println(Arrays.toString(i[j]));

}

Object[][] o=turnA(i);

for(int j=0;jo.length;j++){

System.out.println(Arrays.toString(o[j]));

这是static void main里的一段验证程序,程序最前面需要

import java.util.*;

用JAVA程序写出一个3*3矩阵的转置

/**

* @author 熙熙

* @2011-4-20

*/

public class JuZhenZhuanZhi {

/**

* @param args

*/

public static void main(String[] args) {

int a[][]={

{11,12,13}

,{21,22,23}

,{31,32,33}

};

System.out.println("转置前的矩阵:");

print(a);

zhuanZhi(a);

System.out.println("转置后的矩阵:");

print(a);

}

public static void zhuanZhi(int a[][]){

for(int i=0;ia.length;i++){

for(int j=i+1;ja[i].length;j++){

int tem = a[i][j];

a[i][j] = a[j][i];

a[j][i] = tem;

}

}

}

public static void print(int a[][]){

for(int i=0;ia.length;i++){

int j=0;

for(;ja[i].length-1;j++){

System.out.print(a[i][j]+",");

}

System.out.println(a[i][j]);

}

}

}

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。