1、将一维数组中的元素序列输出成循环移位方阵,可指定移位方向和移动位数。
例如,将{7,4,8,9,1,5}序列元素按右移一位方式输出的循环移位方阵如下:
7 4 8 9 1 5
5 7 4 8 9 1
1 5 7 4 8 9
9 1 5 7 4 8
8 9 1 5 7 4
例如,将{7,4,8,9,1,5}序列元素按右移一位方式输出的循环移位方阵如下:
7 4 8 9 1 5
5 7 4 8 9 1
1 5 7 4 8 9
9 1 5 7 4 8
8 9 1 5 7 4
4 8 9 1 5 7
import java.util.Scanner;
class asd
{
public static void main(String[] args)
{
int a[];
a=new int[]{7,4,8,9,1,5};
for ( int j=0;j<a.length ;j++ )
{
System.out.print(a[j]+" ");
}
System.out.println("请输入一个小于6的正数m代表右移动格数 负数代表向左移动格数");
Scanner myScanner=new Scanner(System.in);
int m=myScanner.nextInt();
int k=m;
if(m>0){
for(int i=0;i<m;i++){
System.out.print(a[6-k]+" ");
k--;
}
for(int i=0;i<(6-m);i++){
System.out.print(a[i]+" ");
}
}
if(m<0)
{
m=6+m;
k=6+k;
for(int i=0;i<m;i++){
System.out.print(a[6-k]+" ");
k--;
}
for(int i=0;i<(6-m);i++){
System.out.print(a[i]+" ");
}
}
myScanner.close();
}
}
class asd
{
public static void main(String[] args)
{
int a[];
a=new int[]{7,4,8,9,1,5};
for ( int j=0;j<a.length ;j++ )
{
System.out.print(a[j]+" ");
}
System.out.println("请输入一个小于6的正数m代表右移动格数 负数代表向左移动格数");
Scanner myScanner=new Scanner(System.in);
int m=myScanner.nextInt();
int k=m;
if(m>0){
for(int i=0;i<m;i++){
System.out.print(a[6-k]+" ");
k--;
}
for(int i=0;i<(6-m);i++){
System.out.print(a[i]+" ");
}
}
if(m<0)
{
m=6+m;
k=6+k;
for(int i=0;i<m;i++){
System.out.print(a[6-k]+" ");
k--;
}
for(int i=0;i<(6-m);i++){
System.out.print(a[i]+" ");
}
}
myScanner.close();
}
}
2、找出一个二维数组的鞍点。
鞍点指某数组元素的值在该行上最大、在列上最小。也可能没有鞍点。
public class andian {
public static void main(String[] args) {
int i,j,maxofrow,maxofcol;
int[][] a = {{3,2,1},{4,2,2},{5,3,3}};
for ( i = 0; i<3; i++ ) {
maxofrow = a[i][0];
maxofcol = 0;
for ( j=1; j<3; j++ ) {
if ( maxofrow<a[i][j] ) {
maxofrow = a[i][j];
maxofcol = j;
}
}//找出了行最大
for ( j=0; j<3; j++ ) {
if ( maxofrow >a[j][maxofcol] ) {
System.out.println("第"+i+"行无鞍点");break; }
else{
System.out.println("第"+i+"行有鞍点,鞍点是"+maxofrow); break;
}
}
}
}
}
public static void main(String[] args) {
int i,j,maxofrow,maxofcol;
int[][] a = {{3,2,1},{4,2,2},{5,3,3}};
for ( i = 0; i<3; i++ ) {
maxofrow = a[i][0];
maxofcol = 0;
for ( j=1; j<3; j++ ) {
if ( maxofrow<a[i][j] ) {
maxofrow = a[i][j];
maxofcol = j;
}
}//找出了行最大
for ( j=0; j<3; j++ ) {
if ( maxofrow >a[j][maxofcol] ) {
System.out.println("第"+i+"行无鞍点");break; }
else{
System.out.println("第"+i+"行有鞍点,鞍点是"+maxofrow); break;
}
}
}
}
}