蛇形填数

描述
在n*n方陈里填入1,2,...,n*n,要求填成蛇形。例如n=4时方陈为:
10 11 12 1
9 16 13 2
8 15 14 3
7 6 5 4
输入
直接输入方陈的维数,即n的值。(n<=100)
输出
输出结果是蛇形方陈。
样例输入
3
样例输出
7 8 1 6 9 2 5 4 3




#include<iostream> 
using namespace std;
int array[100][100];
int main(){
	int test;
	cin>>test;
	int index = 1; 
	for( int k = 0; k <= ( test - 1 ) / 2; k++ ){
		for(int j = k; j < k + ( test - 2 * k ); j ++ ){
			array[ j ][ test - 1 - k ] =  index;
			array[ test - k - 1 ][ test - 1 - j ] = index + test - 2 * k - 1;
			array[ test - 1 -j ][ k ] = index + 2 * ( test - 2 * k ) - 2;
			if( j != k + ( test - 2*k ) - 1){
				array[ k ][ j ] = index + 3 * ( test - 2 * k) - 3 ;
			}
			index++; 
		}
		index += 3 * ( test - 2 * k)-4;
	}
	for( int n = 0; n < test; n ++ ){
		for( int m = 0; m < test; m ++ ){
			cout<< array[ n ][ m ] << " ";
		}
		cout<<endl;
	}
	return 0;
}





你可能感兴趣的:(蛇形填数)