sjsky 发表于 2008-4-20 20:55

关于数组的问题

定义一个数组a[2][2],规定数组的每一行和每一列的元素的值不能相等
已知a[0][0]=1;数组元素的值只能是1或2.
求其他元素的值。
这个程序用C++应该怎么编啊?
求助中...

aipb2007 发表于 2008-4-20 23:18

[code]
bool check(int a[2][2],int n);
void fill(int a[2][2],int n){
        if (n == 2*2){
                for (int i = 0;i < 2;++i){
                        for (int j = 0;j < 2;++j)
                                cout << a[i][j] << " ";
                        cout << endl;
                }
                return;
        }
        for (int i = 1;i <= 2;++i){
                        a[n/2][n%2] = i;
                        if (check(a,n))
                                fill(a,n+1);
        }
        return;
}
[/code]

check自己写,判断满足条件返回true。

可以扩展为任意数,只需改变下参数即可(2->N),这样的话check难写一点。

sjsky 发表于 2008-4-22 00:03

回复 2# 的帖子

麻烦把check也写了吧。
我比较菜a...

aipb2007 发表于 2008-4-22 00:35

不是吧,最简单的

分别判读n = 0,1,2,3 表示填进去了几个值
n == 2
a[0][0] a[0][1]
a[1][0]
满足你的条件就返回true
a[0][0] == a[0][1]
    return false;
a[0][0] == a[1][0]
    return false;
……

当然,这种方法不具备扩展到n>2,但是是很直接的。

yuyunliuhen 发表于 2008-4-22 04:03

[tk05]

页: [1]

编程论坛