阅读 78654 次
发表时间:2009-12-11
public class PaintNumberImage {
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		int source = scanner.nextInt();
		int[][] images = new int[source][source];
		images[0][0] = 1;
		// 北
		boolean isNorth = false;
		// 东
		boolean isEast = false;
		// 南
		boolean isSouth = false;
		// 西
		boolean isWest = true;
		// 最大下标
		int maxIndex = source - 1;
		for (int i = 0; i < source;) {
			if (isWest) {
				for (int j = 1; j < source; j++) {
					if (images[i][j] == 0) {
						images[i][j] = images[i][j - 1] + 1;
					}
				}
				isWest = false;
				isEast = true;
			}
			else if (isEast) {
				for (int j = 1; j < source; j++) {
					if (images[j][maxIndex - i] == 0) {
						images[j][maxIndex - i] = images[j - 1][maxIndex - i] + 1;
					}
				}
				isEast = false;
				isSouth = true;
			}
			else if (isSouth) {
				for (int j = maxIndex; j >= 0; j--) {
					if (images[maxIndex - i][j] == 0) {
						images[maxIndex - i][j] = images[maxIndex - i][j + 1] + 1;
					}
				}
				isSouth = false;
				isNorth = true;
			}
			else if (isNorth) {
				 for (int j = maxIndex; j >= 0; j--) {
					if (images[j][0 + i] == 0) {
						images[j][0 + i] = images[j + 1][0 + i] + 1;
					}
				}
				isNorth = false;
				isWest = true;
				i++;
			}
		}
		for (int i = 0; i < images.length; i++) {
			System.out.println(Arrays.toString(images[i]));
		}
	}
}


也附上实现代码
发表时间:2009-12-11
#include <stdio.h>

main()
{
    int a[10][10]={0},i=1,j=0,value=1,n,stauts=1,k;//i:行号,j:列号
    printf("Input the number n(n<9):\n");
    scanf("%d",&n);
    for(k=0;k<=n+1;k++)
      a[0][k]=a[n+1][k]=a[k][0]=a[k][n+1]= 8;  //设定边界                
    while(value<=n*n)
    {
      j+=stauts;                            
      while(a[i][j]<1)
      {                            
        a[i][j]=value++;
        j+=stauts;             
      }
      j-=stauts;
      i+=stauts;
      while(a[i][j]<1)
      {                            
        a[i][j]=value++;
        i+=stauts;            
      }
      i-=stauts;
      stauts*= -1;
    }  
    for(i=1;i<=n;i++)
    {
      for(j=1;j<=n;j++)
        printf("%4d",a[i][j]);
      printf("\n");                  
    }                
}



用c语言写了一个,通过使用边界设定,合理使用状态变化量(stauts),减少判定语句,精简代码;
发表时间:2009-12-11
遇到过比这更囧的,行列不等的二维数组,数字,字母都有。
当时的算法也是递归调用外层的方框。
发表时间:2009-12-11
/**
 * @author Heis
 * @date Dec 11, 2009
 */
public class SnakeNum {

	
	public static void main(String[] args){
		int n=7;
		SnakeNum.print(SnakeNum.fill(n));		
	}
	/**
	 * 
	 * 算法复杂度为n
	 * 测试结果n=1000时,大概用时70ms
	 * 以下的算法,在for循环内的一些计算是不必要的,可以用变量保存,但是为了代码更加直观,就不做优化了。
	 * 
	 * @param n 矩阵边长
	 */
	public static int[][] fill(int n){
		Long startTime=System.currentTimeMillis();
		//第几圈
		int count=0;
		//转弯步数
		int step;
		//总圈数
		int all;
		//某圈开始累加的基数
		int startNum=0;
		//用于数组下标计算
		int startIndex;
		int k;
		int[][] array=null;
		if(n>0){
			array=new int[n][n];
		    all=n/2+n%2;
		    while(all>=count){
		    	step=n-1-(count<<1);
		    	count++;
		    			    	
		    	for(startIndex=count-1,k=1;k<step+1;k++){
		    		array[count-1][startIndex++]=startNum+k;	
		    	}
		    	
		    	for(startIndex=count-1,k=1;k<step+1;k++){
		    		array[startIndex++][n-count]=startNum+k+step;
		    	}
		    	
		    	for(startIndex=n-count,k=1;k<step+1;k++){
		    		array[n-count][startIndex--]=startNum+k+2*step;
		    	}
		    	
		    	for(startIndex=n-count,k=1;k<step+1;k++){
		    		array[startIndex--][count-1]=startNum+k+3*step;
		    	}
		    	startNum=4*step+startNum;
		    	
		    }
		    if(n%2>0){
		    	int mid=all-1;
		    	array[mid][mid]=n*n;
		    }
		}
		Long timeUsed=System.currentTimeMillis()-startTime;
		System.out.println("总用时:"+timeUsed+"ms");
		return array;		
	}
	
	/**
	 * 打印数组
	 * 
	 * @param array
	 */
	public static void print(int[][] array){
		if(array!=null){
			int n=array.length;
			int i=0,j;
			int count=Integer.valueOf(n*n).toString().length()+1;
			for(;i<n;i++){
				for(j=0;j<n;j++){
					System.out.printf("%"+count+"d",array[i][j]);
				}
				System.out.println();
			}
		}
	}
}
发表时间:2009-12-11
jenlp110 写道
一个画图程序 要求打印出

哥们 这拉丁矩阵是算法基础吧。无可厚非

发表时间:2009-12-11
用数组做,应该不难
发表时间:2009-12-11
我用递归算法做的

public class Xl {

public static void main(String[] args) {
int i = 8;
Integer[][] disp = new Integer[i][i];
disp = core(disp,1,i,1,i*i);
for (int m = 0;m < i;m++) {
for (int n = 0;n < i;n++) {
System.out.print(disp[m][n]+" ");
}
System.out.println();
}
}

public static Integer[][] core(Integer[][] result,int seq,int in,int gradation,int end) {
Integer[][] temp = result;
if (seq == end || seq == end-3) {
if (seq == end) {
temp[gradation-1][gradation-1] = new Integer(seq);
} else {
temp[gradation-1][gradation-1] = new Integer(seq);
temp[gradation-1][gradation] = new Integer(seq+1);
temp[gradation][gradation] = new Integer(seq+2);
temp[gradation][gradation-1] = new Integer(seq+3);
}
return temp;
}
temp = core(temp,seq+((in-(gradation-1)*2-1)*4),in,gradation+1,end);
for (int i = 0;i < (in-(gradation-1)*2)-1; i++) {
temp[gradation-1][i+gradation-1] = new Integer(seq+i);
temp[i+gradation-1][in-gradation] = new Integer(seq+(in-(gradation-1)*2)-1+i);
temp[in-gradation][in-gradation-i] = new Integer(seq+((in-(gradation-1)*2)-1)*2+i);
temp[in-gradation-i][gradation-1] = new Integer(seq+((in-(gradation-1)*2)-1)*3+i);
}
return temp;
}

}
发表时间:2009-12-11
5x5  (5,4;4,3;3,2;2,1;1,0)
6x6  (6,5;5,4;4,3;3,2;2,1;1,0)
发表时间:2009-12-11
花半个小时写的,比较粗糙

public class Print {
	int startNumber = 1;

	public Print() {

	}

	// public void
	public void doPrint(int number) {

		String[][] row = null;
		row = init(row, number);
		printMatrix(row, number);
		
		int size=number;

		System.out.println("new Matirx");
		
		int x=0;
				
		for (;number>2;number=number-1){
			row = setValue(row, number,x);
			x++;
		}
		

		printMatrix(row, size);

	}

	public String[][] setValue(String[][] row, int number, int x) {
		
		for (int q = 0; q < 4; q++) {
			for (int i = 0; i < number; i++) {
				if (q == 0)
					if (row[x][i].equals("x"))
						row[x][i] = String.valueOf(startNumber);
					else
						startNumber--;
				if (q == 1)
					if (row[i][number - 1].equals("x"))
						row[i][number - 1] = String.valueOf(startNumber);
					else
						startNumber--;
				if (q == 2)
					if (row[number - 1][number - 1 - i].equals("x"))
						row[number - 1][number - 1 - i] = String
								.valueOf(startNumber);
					else
						startNumber--;
				if (q == 3)
					if (row[number - 1 - i][x].equals("x"))
						row[number - 1 - i][x] = String.valueOf(startNumber);
					else
						startNumber--;
				startNumber++;
			}
		}
		

		return row;

	}

	public String[][] init(String[][] row, int size) {
		row = new String[size][size];
		for (int i = 0; i < size; i++) {
			for (int q = 0; q < size; q++)
				row[i][q] = "x";
		}

		return row;

	}

	public void printMatrix(String[][] row, int size) {
		for (int i = 0; i < size; i++) {
			for (int q = 0; q < size; q++)
				System.out.print(row[i][q] + ",");
			System.out.println("\n");
		}

	}

}

发表时间:2009-12-12
在下从物理学角度出发,贴个代码:
package movement;
/**
 * 
 * @author PS
 *
 */
public class Point {
	private int x;
	private int y;
	private int value;
	public Point(){}
	public Point(int x,int y,int value){
		this.x=x;
		this.y=y;
		this.value=value;
	}
	public int getValue() {
		return value;
	}
	public void setValue(int value) {
		this.value = value;
	}
	public int getX() {
		return x;
	}
	public void setX(int x) {
		this.x = x;
	}
	public int getY() {
		return y;
	}
	public void setY(int y) {
		this.y = y;
	}
}
-----------------------------------------------------------
package movement;

public class Direct {
	public static final int RIGHT=1;
	public static final int DOWN=2;
	public static final int LEFT=3;
	public static final int UP=4;
}
-----------------------------------------------------------
package movement;

import java.util.ArrayList;
import java.util.List;

public class Track {
	public static final int[] sequence={Direct.RIGHT,Direct.DOWN,Direct.LEFT,Direct.UP};
	private int currentDirect=sequence[0];
	private int size;
	private Point currentPoint=new Point(0,0,1);
	private List<Point> pointList=new ArrayList<Point>();
	private int getNextDirect(){
		int i=0;
		for(;i<sequence.length;i++){
			if(currentDirect==sequence[i]) break;
		}
		if(i!=sequence.length-1){
			return sequence[++i];
		}else{
			return sequence[0];
		}
	}
	private boolean isExist(Point p){
		for(Point o:pointList){
			if(p.getX()==o.getX()&&p.getY()==o.getY()){
				return true;
			}
		}
		return false;
	}
	private Point countNextPoint(Point p,int direct){
		Point o=new Point();
		switch(direct){
		case Direct.RIGHT:
			o.setX(p.getX()+1);
			o.setY(p.getY());
			break;
		case Direct.DOWN:
			o.setX(p.getX());
			o.setY(p.getY()+1);
			break;
		case Direct.LEFT:
			o.setX(p.getX()-1);
			o.setY(p.getY());
			break;
		case Direct.UP:
			o.setX(p.getX());
			o.setY(p.getY()-1);
			break;
		}
		o.setValue(p.getValue()+1);
		return o;
	}
	private void createPointList(){
		while(this.currentPoint.getValue()<=size*size){
			pointList.add(this.currentPoint);
			//计算下一个currentPoint
			Point nextPoint=countNextPoint(currentPoint, currentDirect);
			//下一个点越界或者位置已经被占据,则变向,并重新计算下一个点

			if(nextPoint.getX()<0||nextPoint.getX()>=size
					||nextPoint.getY()<0||nextPoint.getY()>=size
					||isExist(nextPoint)){
				currentDirect=getNextDirect();
				nextPoint=countNextPoint(currentPoint, currentDirect);
			}
			currentPoint=nextPoint;
		}
	}
	public Point[][] getPointArray(){
		createPointList();
		Point[][] valueArray=new Point[size][size];
		for(Point p:pointList){
			valueArray[p.getY()][p.getX()]=p;
		}
		return valueArray;
	}
	public void setSize(int size) {
		this.size = size;
	}
	public static void main(String[] args) {
		long beginTime=System.currentTimeMillis();
		int size=10;
		Track t=new Track();
		t.setSize(size);
		Point[][] valueArray=t.getPointArray();
		int len=(size*size+"").length();
		int blankLen=0;
		for(int i=0;i<size;i++){
			for(int j=0;j<size;j++){
				blankLen=len-(valueArray[i][j].getValue()+"").length();
				for(int k=0;k<blankLen;k++){
					System.out.print(" ");
				}
				System.out.print(valueArray[i][j].getValue()+" ");
			}
			System.out.println();
		}
		System.out.println("用时:"+(System.currentTimeMillis()-beginTime)+"ms");
	}

}
Global site tag (gtag.js) - Google Analytics