矩阵旋转java代码,旋转矩阵算法代码

用java:利用二维数组,任意给出一个矩阵,编写实现矩阵转置的代码

借花献佛

科尔沁右翼中ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:13518219792(备注:SSL证书合作)期待与您的合作!

/**

* 实现二维数组的转置

* @author HAN

*

*/

public class transposition_Arrays2D_ch6_4 {

final static double PI=3.1415;

public static void main(String[] args) {

/*StaticTest st1=new StaticTest();

StaticTest st2=new StaticTest();

st1.method2("HAN");*/

/*****定义要用于转置的二维数组*******/

int arr2D[][]={{1,2,3},{4,5,6},{7,8,9}};

/*****构造结果新二维数组用于存放转置结果*******/

/*定义结果数组变量,注意 一定要先开辟一个内存,

否则只是地址传递,也就是说两个数组名实际上指向的是同一块内存*/

//而构造二维数组可以为维度来进行,不一定是一个矩阵,即每一行的长度不一定相同

int result_arr[][]=new int[arr2D.length][];//先实现第一维

for(int i=0 ; iarr2D.length;i++){ //再实现第二维

result_arr[i]=new int[arr2D[i].length];

}

// int result_arr[][]=Arrays.copyOf(arr2D, arr2D.length);

//上面这个命令行行不通!

/*****输出用于转置的二维数组*******/

for (int x[]:arr2D){

for(int e:x){

System.out.print(e+" ");

}

System.out.println();

}

System.out.println();

/*******进行元素倒置******/

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

for(int j=0; jarr2D[i].length;j++){

result_arr[j][i]=arr2D[i][j]; //转置核心

}

}

/*****show the result in the result matrix*******/

for (int x[]:result_arr){

for(int e:x){

System.out.print(e+" ");

}

System.out.println();

}

}

}

//import java.util.Arrays;

//public class transposition_Arrays2D {

//

// public static void main(String[] args) {

// int arr2D[][]={{1,2,3},{4,5,6},{7,8,9}};

// /*定义结果数组变量,注意 一定要先开辟一个内存,

// 否则只是地址传递,也就是说两个数组名实际上指向的是同一块内存*/

// int result_arr[][]=new int[arr2D.length][];

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

// result_arr[i]=new int[arr2D[i].length];

// }

//

//        // 进行元素倒置

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

//         for(int j=0; jarr2D[i].length;j++){

//         result_arr[j][i]=arr2D[i][j];

//         }

//        }

//        

//        // show the result in matrix

//        for (int x[]:result_arr){

//         for(int e:x){

//         System.out.print(e);

//         }

//         System.out.println();

//        }

//        

// }

//

//}

参考下面的代码,用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程序写出一个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]);

}

}

}

如何用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代码,旋转矩阵算法代码
分享URL:http://scyanting.com/article/hciigh.html