关于数组的问题
定义一个数组a[2][2],规定数组的每一行和每一列的元素的值不能相等已知a[0][0]=1;数组元素的值只能是1或2.
求其他元素的值。
这个程序用C++应该怎么编啊?
求助中...
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难写一点。
回复 2# 的帖子
麻烦把check也写了吧。我比较菜a... 不是吧,最简单的
分别判读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,但是是很直接的。 [tk05]
页:
[1]
