谭浩强魔方阵看不明白的同学看这里
来源:互联网 发布:杭州市大数据局 编辑:程序博客网 时间:2024/05/06 19:12
#define _CRT_SECURE_NO_WARNINGS#include <stdio.h>int main(){int a[15][15], i, j, k, p, n;p = 1;while (p == 1){printf("enter n(1--15):\n"); //要求阶数为1~15之间的奇数scanf("%d", &n); //答案输入的是5if ((n != 0) && (n <= 15) && (n % 2 != 0))p = 0;} //这个如果不是输入为奇数,会一直让你输入下去,直到出现奇数 //初始化for (i = 1; i <= n; i++){for (j = 1; j <= n; j++){ //这里把矩阵i,j初始值全换成1,然后初始化全部清零a[i][j] = 0;}} //建立魔方阵 j = n / 2 + 1;a[1][j] = 1;for (k = 2; k <= n*n; k++){ //这里i的值是6,因为上面已经运行了一圈j是3因为上面的赋值(输入为5)i = i - 1; //这里i,j会自减自加,因为k循环,按要求列式,不多讲k=2时i=5,j=4这时j = j + 1; //a[5][4]==0执行下面if(a[i][j]==0)条件if ((i<1) && (j>n)) {i = i + 2; //比如i=1,做了上面的减法i=0,这时i=2等于是上面一个数空了一行,列向j = j - 1; //前跑了一列}else //i>1||j>n;i>1&&j>n;i>1||j<n;i>1&&j<n;i<1||j<n;i<1&&j<n{ //i<1||j>n;这是一个完整的if elseif (i<1)i = n;if (j>n)j = 1;}if (a[i][j] == 0) //第一个循环因为上面清空了,所以第一次和后面几次给值在这里a[i][j] = k;else //a[i][j]!=0,这下面是一个完整的if else{i = i + 2;j = j - 1;a[i][j] = k;}} //输出魔方阵for (i = 1; i <= n; i++){for (j = 1; j <= n; j++)printf("%5d", a[i][j]);printf("\n");}return 0;}
1 0
- 谭浩强魔方阵看不明白的同学看这里
- 看不明白这个反编译的文件
- 一个看不明白的base.js
- 看这里看这里看这里
- 想学微信公众号开发的同学看这里(java版)
- 看这里
- params 看这里看这里
- 关于 ROBOTS.TXT一些看不明白的东东
- 学习c++的同学看下
- 看了一个同学的博客,想哭
- 注意,看CSDN的会卡的看这里
- 想看"当事人角色"大图片的点这里看
- 想看"当事人角色"大图片的点这里看
- 加我的兄弟姐妹,看这里哦~~
- 想学Python的朋友看这里
- 调试 卡死的问题看这里
- [C++]uva729总是wa的看这里
- HI,myboy,看这里
- 【问题解决】ava.lang.NoSuchMethodError: antlr.collections.AST.getLine()
- Android 异步消息处理机制 让你深入理解 Looper、Handler、Message三者关系
- solr replication原理探究
- OJ 1997: C语言实验——分割整数
- 百度地图开发(一)
- 谭浩强魔方阵看不明白的同学看这里
- 图片压缩
- JNA方式调用dll动态库
- mongodb更新数据
- ZOJ 2334 可并堆<斜堆>
- 基于 base64_encode的加密算法
- 利用matlab对彩色图像打马赛克
- 2016 年 7 个最佳的 Java 框架
- iOS手势