| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1338 人关注过本帖
标题:有点纠结,蛇形矩阵(二维数组),有点bug
取消只看楼主 加入收藏
weipeng1217
Rank: 5Rank: 5
等 级:职业侠客
帖 子:175
专家分:386
注 册:2012-1-12
结帖率:77.78%
收藏
已结贴  问题点数:50 回复次数:2 
有点纠结,蛇形矩阵(二维数组),有点bug
题目:
设计一个二维数组,按图示输出。(蛇形数组)
1  2  6  7
3  5  8 13
4  9 12 14
10 11 15 16


N值为4的时候,能正确输出,但是大于4之后,后面几圈就有问题了。
如图:
图片附件: 游客没有浏览图片的权限,请 登录注册


可能是for(n=1;n<2*N-2;n++)这里对n的控制有问题,当n>=N的时候,如果能n--的话就完美了。。
我不想把代码整的太长,有啥好的办法么?
那个三目运算的判断没搞成。。。


我的代码:
程序代码:
#include <stdio.h>
#define N 4
int count=1;  //初值
int main(int argc,char **argv)
{
    int a[N][N]={0};
    int i,j;
    int n;
    a[0][0] = count++;    
    
    for(n=1;n<2*N-2;n++)
    {
        if(n%2)//偶数
        {
            for(i=0,j=n;j>=0,i<=n;i++,j--)
            {
                if (a[i][j] == 0 )
                
                    a[i][j] = count++;
            }
        }
        
        else //奇数
        {

            for(i=n,j=0;i>=0,j<=n;i--,j++)
            {
                if (a[i][j] == 0 )
                    a[i][j] = count++;
            }    
        }
    }

    a[N-1][N-1] = count++;    
    
    for(i = 0;i < N;i++)//输出结果
    {
        for(j = 0;j < N;j++)
        {
            printf("%3d ",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}


[ 本帖最后由 weipeng1217 于 2013-6-17 22:51 编辑 ]
搜索更多相关主题的帖子: color 
2013-06-17 22:45
weipeng1217
Rank: 5Rank: 5
等 级:职业侠客
帖 子:175
专家分:386
注 册:2012-1-12
收藏
得分:0 
回复 13楼 我叫沃恩
谢谢啦。。
还有更优的算法嘛。。

C坛友交流群 群号:161091913 ,欢迎经常在线的朋友加入,一起学习,一起进步。。
2013-06-18 21:58
weipeng1217
Rank: 5Rank: 5
等 级:职业侠客
帖 子:175
专家分:386
注 册:2012-1-12
收藏
得分:0 
回复 11楼 雪狼MJ
输出的有点小问题,初值可能没给对,不过问题不大,谢谢啦~

C坛友交流群 群号:161091913 ,欢迎经常在线的朋友加入,一起学习,一起进步。。
2013-06-18 22:03
快速回复:有点纠结,蛇形矩阵(二维数组),有点bug
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016847 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved