Inti(intimate)
在C语言中魔方阵程序里inti?
程序代码:
#include<stdio.h>
#define N 16
int main()
{
int a[N][N]={0},i,j,k,p,n;
p=1;
while(p==1)
{
printf("Enter n(1~%d):",N);
scanf("%d",&n);
if((n!=0)&&(n<N)&&(n%2!=0))
p=0;
}
i=n+1;
j=n/2+1;
a[1][j]=1;
for(k=2;k<=n*n;k++)
{
i=i-1;
j=j+1;
if((i<1)&&(j>n))
{
i=i+2;
j=j-1;
}
else
{
if(i<1)i=n;
if(j>n)j=1;
}
if(a<i>[j]==0)a<i>[j]=k;
else
{
i=i+2;
j=j-1;
a<i>[j]=k;
}
}
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
printf("%4d",a<i>[j]);
printf("\n");
}
return 0;
}
扩展资料:
1.第一行中间一列的值为1。
所以用j=n/2+1确定1的列数,得出a[1][j]=1。
2.每一个数存放的行比前一个数的行数减1,列数加1。
行数用i=i-1确定,列数用j=j+1确定。
3.如果一个数行数为第一行,则下一个数行数为最后一行。
4.如果一个列行数为最后一列,则下一个数列数为第一列。
5.如果按上面的规则确定的位置上已有数,或上一个数是第一行最后一列,则把下一个数放在上一个数的下面。
求助#includevoidmain(){inti,j,m=0,n=0?
#include <stdio.h>
void main()
{
int i,j,m,n;
i = 8;
j = 10;
m = ++i;
n = j++;
printf("%d,%d,%d,%d\n",i,j,m,n);
}
① 运行程序,观察 i、j、m、n各变量的值,分析结果。
② 将第7、8行改为:
m=i++;
n=++j;
再运行。此时屏幕输出什么?并分析原因
③ 将程序改为:
#include <stdio.h>
void main()
{
int i,j,m=0,n=0;
i = 8;
j = 10;
m += i++;
n -= --j;
printf("i=%d,j=%d,m=%d,n=%d\n",i,j,m,n);
}
好了,文章到这里就结束啦,如果本次分享的Inti问题对您有所帮助,还望关注下本站哦!了解更多信息可以在站内搜索。