nyoj33蛇形填数
2015-11-08 16:05
225 查看
#include<stdio.h>
int main()
{
int n,a,i,sum = 1,j;
int sn[101][101];
scanf("%d",&n);
for(i = 0;i <= (n - 1)/2;i++)
{
if(n == 1)
{
printf("1\n");
return 0;
}
else
{
for(a = i;a < n-i;a++)
{
sn[a][n-i-1] = sum++;
}
for(a = n-2-i;a >= i;a-- )
{
sn[n-1-i][a] = sum++;
}
for(a = n-2-i;a >= i;a--)
{
sn[a][i] = sum++;
}
for(a = i+1;a < n -1- i;a++)
{
sn[i][a] = sum++;
}
}
}
for(i = 0;i < n;i++)
{
for(j = 0;j < n;j++)
{
printf("%d ",sn[i][j]);
}
printf("\n");
}
return 0;
}
这道题思路其实知道了就很简单。
int main()
{
int n,a,i,sum = 1,j;
int sn[101][101];
scanf("%d",&n);
for(i = 0;i <= (n - 1)/2;i++)
{
if(n == 1)
{
printf("1\n");
return 0;
}
else
{
for(a = i;a < n-i;a++)
{
sn[a][n-i-1] = sum++;
}
for(a = n-2-i;a >= i;a-- )
{
sn[n-1-i][a] = sum++;
}
for(a = n-2-i;a >= i;a--)
{
sn[a][i] = sum++;
}
for(a = i+1;a < n -1- i;a++)
{
sn[i][a] = sum++;
}
}
}
for(i = 0;i < n;i++)
{
for(j = 0;j < n;j++)
{
printf("%d ",sn[i][j]);
}
printf("\n");
}
return 0;
}
这道题思路其实知道了就很简单。
相关文章推荐
- IOS-图片操作集合
- 【HDU 4786 Fibonacci Tree】最小生成树
- 按钮添加边框和边框色
- 典型用户故事
- Android读书笔记-----自定义View(1)原理
- JAVA高性能网络编程——牛刀小试
- UVa 127 Accordian Patience
- dlopen动态函数库的加载。
- 泛型相关知识
- 前序创建二叉树+ 前序/中序/后序遍历二叉树
- OSGI的类加载机制
- 20135337——信息安全设计基础第八周学习笔记
- 20135220谈愈敏--信息安全系统设计基础第八周学习总结
- 近视矫正手术:准分子激光,飞秒,全飞秒
- VS2010配置C/C++多线程使用环境
- 当刘小立访问Google时,刘小立如何能访问? ---《计算机网络-自顶向下方法》
- linux命令-bzip2压缩
- Linux expect命令
- Linux之NFS基础总结及应用实践
- swift 重载 泛式 inout的使用