㈠ c語言 輸出字元回形陣
#include<stdio.h>
void main()
{int i,j,N;
char k,b,c,d,a;
scanf("%d %c",&N,&k);
if(N%2==0)
printf("%d is not a odd number!\n",N);
else if(N<24)
{ for(i=1;i<=N;i++)
{ for(j=1;j<=N;j++)
{ b=k-N/2+i-1;
c=k-N/2+N-j;
d=k-N/2+j-1;
a=k-N/2+N-i;
if(i<=j && i<=(N-j+1))
{if(k<=90 && b<=64) b=90-(64-b)%26;
if(k>=97 && b<=96) b=122-(96-b)%26;
printf("%c",b);}
if(i<=j && i>(N-j+1))
{if(k<=90 && c<=64) c=90-(64-c)%26;
if(k>=97 && c<=96) c=122-(96-c)%26;
printf("%c",c);}
if(i>j && i<=(N-j+1))
{if(k<=90 && d<=64) d=90-(64-d)%26;
if(k>=97 && d<=96) d=122-(96-d)%26;
printf("%c",d);}
if(i>j && i>(N-j+1))
{if(k<=90 && a<=64) a=90-(64-a)%26;
if(k>=97 && a<=96) a=122-(96-a)%26;
printf("%c",a);}
if(j!=N) printf(" ");}
printf("\n");}
}
}
好吧這不是我寫的,但是呢,的確是正確答案........我抄同學的,已經提交了,是對的。
㈡ 想用c語言實現 回形數組 代碼該怎麼編寫
#include<stdio.h>
#defineN100
/*實現回形數組*/
intmain()
{
intarray[N][N];
intdimension;
inti,j,num,start,end;
scanf("%d",&dimension);//輸入回形數組維度。
num=0;
for(i=0;i<dimension;i++){
for(j=0;j<dimension;j++){
printf("%3d",num++);
}
printf(" ");
}
printf(" ");
num=1;
start=0;
end=dimension;
while(1){
for(i=j=start;j<end;j++){//上行
array[i][j]=num++;
}
for(i++,j--;i<end;i++){//右列
array[i][j]=num++;
}
for(i--,j--;j>=start;j--){//下行
array[i][j]=num++;
}
for(i--,j++;i>start;i--){//左列
array[i][j]=num++;
}
start++;
end--;
if(start>=end)
break;
}
/*列印*/
for(i=0;i<dimension;i++){
for(j=0;j<dimension;j++){
printf("%3d",array[i][j]);
}
printf(" ");
}
return0;
}
㈢ 編程二維數組回形遍歷如何寫程序(C語言)
呵呵,我以前寫過,是用java寫的,給你看下java源碼,以供參考,希望對你有幫助.
java與c++語法差不多,入口是main()方法
package test;
/**
* 列印回行圖案
16 15 14 13
5 4 3 12
6 1 2 11
7 8 9 10
* @author zhanngle
*
*/
public class Round {
public static void main(String[] args) {
int row=10; //幾行
int col=10; //幾列
int[][] a=new int[row][col];
fill(a,row,col,0,0);
print(a);
}
/**
* 填寫最外一圈的數據,如果還有內圈數據,則遞歸調用本身繼續填寫內圈數據,直到填寫完畢
* @param a
* @param row
* @param col
* @param i
* @param j
*/
private static void fill(int [][] a,int row,int col,int i,int j) {
int n=row*col;
for(int c=0;c<=col-1;c++) { //橫向填充數值
a[i][j+c]=n-c; //在首行從左到右填值
if(row!=1)
a[i+row-1][j+c]=n-(col*2+row-3)+c; //如果不只1行,在末行從左到右填值
}
for(int r=0;r<row-2;r++) { //豎向填充數值
a[i+row-2-r][j]=a[i+row-1][j]-r-1; //在首列從下往上填值
if(col!=1) //如果不只1列,大末列從下往上填值
a[i+row-2-r][j+col-1]=a[i+row-1][j+col-1]+r+1;
else //否則覆蓋首列數據
a[i+row-2-r][j]=a[i+row-1][j]+r+1;
}
if(row-2>0 && col-2>0) fill(a,row-2,col-2,i+1,j+1); //如果還沒填完數據,則遞歸填寫
}
/**
* 列印二維數組
* @param a
*/
private static void print(int[][] a) {
for(int i=0;i<a.length;i++) {
for(int j=0;j<a[0].length;j++) {
System.out.printf("%4d",a[i][j]);
}
System.out.println();
}
}
}