实现蛇形输出
2016-12-13 21:51
176 查看
实现如下的蛇形输出:
1 2 3 4 5
16 17 18 19 6
15 24 25 20 7
14 23 22 21 8
13 12 11 10 9
具体代码实现:
[html] view
plain copy
#include <stdio.h>
#include <malloc.h>
int main()
{
int n;
int x,y,round;
//a[x][y],x是二维数组的第一个下标,y是二维数组的第二个下标,
//round是转的圈数,从0开始。
int count = 1;//从1开始计数
printf("Please input a number:\n");
scanf("%d",&n);//用户输入n的值
int (*a)
= calloc(n * n,sizeof(int));//创建n*n的矩阵
for(round = 0; round < n / 2; round++)
{
x = round;
for(y = round; y < n - round; y++)
{
a[x][y] = count;
count++;
}
//print 1,2,3,4,5
y = n - round - 1;
for(x = round + 1; x < n - round - 1; x++)
{
a[x][y] = count;
count++;
}
//print 6,7,8
x = n - round - 1;
for(y = n - round - 1; y >= round; y--)
{
a[x][y] = count;
count++;
}
//print 13,12,11,10,9
y = round;
for(x = n - round - 2; x > round; x--)
{
a[x][y] = count;
count++;
}
//print 16,15,14
}
if(n % 2 == 1)
{
a[n / 2][n / 2] = n * n;
}
for(x = 0 ; x < n; x++)
{
for(y = 0; y < n; y++)
{
printf(" %d ",a[x][y]);
}
printf("\n");
}
free(a);
return 0;
}
1 2 3 4 5
16 17 18 19 6
15 24 25 20 7
14 23 22 21 8
13 12 11 10 9
具体代码实现:
[html] view
plain copy
#include <stdio.h>
#include <malloc.h>
int main()
{
int n;
int x,y,round;
//a[x][y],x是二维数组的第一个下标,y是二维数组的第二个下标,
//round是转的圈数,从0开始。
int count = 1;//从1开始计数
printf("Please input a number:\n");
scanf("%d",&n);//用户输入n的值
int (*a)
= calloc(n * n,sizeof(int));//创建n*n的矩阵
for(round = 0; round < n / 2; round++)
{
x = round;
for(y = round; y < n - round; y++)
{
a[x][y] = count;
count++;
}
//print 1,2,3,4,5
y = n - round - 1;
for(x = round + 1; x < n - round - 1; x++)
{
a[x][y] = count;
count++;
}
//print 6,7,8
x = n - round - 1;
for(y = n - round - 1; y >= round; y--)
{
a[x][y] = count;
count++;
}
//print 13,12,11,10,9
y = round;
for(x = n - round - 2; x > round; x--)
{
a[x][y] = count;
count++;
}
//print 16,15,14
}
if(n % 2 == 1)
{
a[n / 2][n / 2] = n * n;
}
for(x = 0 ; x < n; x++)
{
for(y = 0; y < n; y++)
{
printf(" %d ",a[x][y]);
}
printf("\n");
}
free(a);
return 0;
}
相关文章推荐
- 创建类型数据
- 临时表空间空间不足解决方法
- 阿里面试题总结(二)
- 内存溢出
- AOP、Filter、拦截器,花落知多少
- bind1st和bind2nd
- STM32cubemx USB CDC
- CSDN维护了,还好空间还能继续使用
- CS231n课程笔记翻译
- 反转链表--Java实现
- Linux基础介绍【第四篇】
- javascript 字符串多行的写法
- 费诺编码
- HDU 1710 二叉树水题
- POJ 1463 Strategic game
- Eclipse代码格式化无效解决方案
- JSTL标准标签库核心标签的使用
- thinkphp 时间戳转为日期时间格式
- 无限制,开放式匿名聊天,陌路人,websocket
- windows下mysql客户端输入中文显示??解决方法