| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4431 人关注过本帖
标题:“感叹号”问题
只看楼主 加入收藏
流川の
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-7-27
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:10 
“感叹号”问题
题目:在n*n方阵里填入1,2,。。。。,3,n*n,要求填成蛇形。例如n=4时方阵为:
10 11 12 1
 9 16 13 2
 8 15 14 3
 7  6  5 4
上面的方阵中,多余的空格只是为了便于观察规律,不必严格输出。n<=8.
程序为:
#include<stdio.h>
#include<string.h>
#define INF 10
int a[INF][INF];
int main()
{
    int n,x,y,tot=0;
    scanf("%d",&n);
    memset(a,0,sizeof(a));
    tot=a[x=0][y=n-1]=1;
    while(tot<n*n)
    {
        while(x+1<n&&!a[x+1][y])
            a[++x][y]=++tot;
        while(y-1>=0&&!a[x][y-1])
            a[x][--y]=++tot;
        while(x-1>=0&&!a[x-1][y])
            a[--x][y]=++tot;
        while(y+1<n&&!a[x][y+1])
            a[x][++y]=++tot;
    }
    for(x=0;x<n;x++)
    {
        for(y=0;y<n;y++)
            printf("%3d",a[x][y]);
        printf("\n");
    }
    return 0;
}
请问第13,15,17,19行中"!a[][]"是什么意思?应该怎么应用?
跪求高手指点迷津!!!
搜索更多相关主题的帖子: include 感叹号 
2013-07-31 19:07
天楚
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:楚地
等 级:小飞侠
帖 子:550
专家分:2113
注 册:2013-3-14
收藏
得分:0 
就是矩阵填数的方法啊!

没有哪条路好走,选择了,就坚持下去~~~~
2013-07-31 19:22
guhemeng
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:100
专家分:165
注 册:2013-7-27
收藏
得分:5 
! 的本意你肯定知道把,那具体的逻辑,你可以自己设定一个 n 的值,一步一步往下走。  学习最主要的是学到解决问题的方法,别人告诉你结果没用的,下回要你写一段代码,肯定没法着手!
2013-07-31 21:31
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:0 
求是否填值...自己调试一下啊,亲...

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-08-01 08:10
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
程序代码:
#include<stdio.h>

int main()
{
    int a[10][10]={0};      //最大矩阵10*10
    int n=8;                //输出8*8 矩阵
    int x,y,tot;
    x=0;
    y=n-1;
    a[x][y]=1;
    tot=1;
    while(tot<n*n)
    {
        while(x+1<n  && a[x+1][y]==0)   a[++x][y]=++tot;   //填充矩阵右边
        while(y-1>=0 && a[x][y-1]==0)   a[x][--y]=++tot;   //填充矩阵下边
        while(x-1>=0 && a[x-1][y]==0)   a[--x][y]=++tot;   //填充矩阵左边
        while(y+1<n  && a[x][y+1]==0)   a[x][++y]=++tot;   //填充矩阵上边
    }
    for(x=0;x<n;x++)
    {
        for(y=0;y<n;y++) printf("%3d",a[x][y]);
        printf("\n");
    }
    return 0;
}
据书上讲   !a[x][y] 是比较正规的写法吧  但是我不喜欢  
小小的改动了一下楼主的代码  vs2010下 测试通过
收到的鲜花
  • 流川の2013-08-03 15:14 送鲜花  1朵  

DO IT YOURSELF !
2013-08-01 08:28
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:0 
上楼有道理

Maybe
2013-08-01 12:28
蚕头燕尾
Rank: 10Rank: 10Rank: 10
来 自:Gryffindo
等 级:贵宾
威 望:12
帖 子:734
专家分:1546
注 册:2013-3-24
收藏
得分:0 
楼主你逗谁呢,写了这么多代码了,

你竟然还那么可爱的把“非”读成“感叹号”

好逗~

学习编程,为的是表达自己的思想,而不是被别人的思想所禁锢。要先明白自己想干嘛,而不要先问别人让你干嘛。               

                                                                                                                    Black Cat      Hello Tomorrow~
2013-08-02 09:29
蚕头燕尾
Rank: 10Rank: 10Rank: 10
来 自:Gryffindo
等 级:贵宾
威 望:12
帖 子:734
专家分:1546
注 册:2013-3-24
收藏
得分:0 
你自己从头走一遍,就会发现下一步的选择有两种,必须用       保证下一步要走的位置是非0的(即以前没有走过的位置,避免重复填数)

这样才能保证是蛇形行走



学习编程,为的是表达自己的思想,而不是被别人的思想所禁锢。要先明白自己想干嘛,而不要先问别人让你干嘛。               

                                                                                                                    Black Cat      Hello Tomorrow~
2013-08-02 09:48
蚕头燕尾
Rank: 10Rank: 10Rank: 10
来 自:Gryffindo
等 级:贵宾
威 望:12
帖 子:734
专家分:1546
注 册:2013-3-24
收藏
得分:15 
额,笔误,上面说错。

应该是:

保证下一步要走的位置是0,也就是还没填过数的位置

因为你把数组初始化为全0了嘛,而且是从1开始填数,所以不可能填一个0

只要不是0的位置就是已经填过数了的位置,不能重复填数

学习编程,为的是表达自己的思想,而不是被别人的思想所禁锢。要先明白自己想干嘛,而不要先问别人让你干嘛。               

                                                                                                                    Black Cat      Hello Tomorrow~
2013-08-02 09:51
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:0 
回复 7楼 蚕头燕尾
他可能是在看别人的代码没看懂...

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-08-02 10:15
快速回复:“感叹号”问题
数据加载中...
 
   



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

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