注册 登录
编程论坛 C++教室

关于数组的问题

sjsky 发布于 2008-04-20 20:55, 473 次点击
定义一个数组a[2][2],规定数组的每一行和每一列的元素的值不能相等
已知a[0][0]=1;数组元素的值只能是1或2.
求其他元素的值。
这个程序用C++应该怎么编啊?
求助中...
4 回复
#2
aipb20072008-04-20 23:18
程序代码:

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;
}


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

可以扩展为任意数,只需改变下参数即可(2->N),这样的话check难写一点。
#3
sjsky2008-04-22 00:03
回复 2# 的帖子
麻烦把check也写了吧。
我比较菜a...
#4
aipb20072008-04-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,但是是很直接的。
#5
yuyunliuhen2008-04-22 04:03
1