145颜色方块(11)

智力游戏




规则和122颜色方块(9)132(10)一样,不过这里变成了16个格子。

代码也是直接将那个代码拓展得到的。

代码:

#include<iostream>
#include<iomanip>
using namespace std;

int same(int i, int j, int k, int l, int x)
{
	if (i == x || j == x || k == x || l == x)return 1;
	else return 0;
}

bool ok(int list[][4], int a, int b, int c, int d)
{
	if ((list[a][3] + list[b][2] + list[c][1] + list[d][0]) == 10)return true;
	return false;
}

bool main2(int list[][4], int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9);
bool main3(int list[][4], int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9, int i10, int i11, int i12);

int main()
{
	int list[17][4];
	cout << "输入每个格子的4个数字" << endl;
	for (int i = 0; i < 16; i++)for (int j = 0; j < 4; j++)cin >> list[i][j];
	list[16][0] = list[16][1] = list[16][2] = list[16][3] = 0;
	for (int i1 = 0; i1 < 16; i1++)for (int i2 = 0; i2 < 16; i2++)for (int i3 = 0; i3 < 16; i3++)
	{
		if (i1 == i2 || i1 == i3 || i2 == i3)continue;
		for (int i4 = 0; i4 < 16; i4++)for (int i5 = 0; i5 < 16; i5++)
		{
			if (i1 == i4 || i2 == i4 || i3 == i4 || !ok(list, 16, i1, i3, i4))continue;
			if (same(i1, i2, i3, i4, i5) || !ok(list, i1, i2, i4, i5))continue;
			for (int i6 = 0; i6 < 16; i6++)for (int i7 = 0; i7 < 16; i7++)
			{
				if (same(i1, i2, i3, i4, i6) || i5 == i6)continue;
				if (same(i1, i2, i3, i4, i7) || i5 == i7 || i6 == i7)continue;
				for (int i8 = 0; i8 < 16; i8++)
				{
					if (same(i1, i2, i3, i4, i8) || i5 == i8 || i6 == i8 || i7 == i8)continue;
					if (!ok(list, i3, i4, i7, i8))continue;
					for (int i9 = 0; i9 < 16; i9++)
					{
						if (same(i1, i2, i3, i4, i9) || same(i5, i6, i7, i8, i9))continue;
						if (!ok(list, i4, i5, i8, i9))continue;
						if (main2(list, i1, i2, i3, i4, i5, i6, i7, i8, i9))return 0;
					}
				}
			}
		}
	}
	return 0;
}


bool main2(int list[][4], int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9)
{
	for (int i10 = 0; i10 < 16; i10++)
	{
		if (same(i1, i2, i3, i4, i10) || same(i5, i6, i7, i8, i10) || i9 == i10)continue;
		if (!ok(list, i5, i6, i9, i10))continue;
		for (int i11 = 0; i11 < 16; i11++)for (int i12 = 0; i12 < 16; i12++)
		{
			if (same(i1, i2, i3, i4, i11) || same(i5, i6, i7, i8, i11) || i9 == i11 || i10 == i11)continue;
			if (!ok(list, i7, i8, 16, i11) || i9 == i12 || i10 == i12 || i11 == i12)continue;
			if (same(i1, i2, i3, i4, i12) || same(i5, i6, i7, i8, i12) || !ok(list, i8, i9, i11, i12))continue;
			if (main3(list, i1, i2, i3, i4, i5, i6, i7, i8, i9, i10, i11, i12))return true;
		}
	}
	return false;
}

bool main3(int list[][4], int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9,int i10,int i11,int i12)
{
	for (int i13 = 0; i13 < 16; i13++)for (int i14 = 0; i14 < 16; i14++)
	{
		if (same(i1, i2, i3, i4, i13) || same(i5, i6, i7, i8, i13) || same(i9, i10, i11, i12, i13))continue;
		if (!ok(list, i2, i13, i5, i6) || list[i2][1] + list[i13][0] != 10)continue;
		if (same(i1, i2, i3, i4, i14) || same(i5, i6, i7, i8, i14) || same(i9, i10, i11, i12, i14))continue;
		if (i13 == i14 || !ok(list, i13, 16, i6, i14))continue;
		for (int i15 = 0; i15 < 16; i15++)for (int i16 = 0; i16 < 16; i16++)
		{
			if (same(i1, i2, i3, i4, i15) || same(i5, i6, i7, i8, i15) || same(i9, i10, i11, i12, i15))continue;
			if (i13 == i15 || i14 == i15||!ok(list, i6, i14, i10, i15) || list[i14][3] + list[i15][1] != 10)continue;
			if (same(i1, i2, i3, i4, i16) || same(i5, i6, i7, i8, i16) || same(i9, i10, i11, i12, i16))continue;
			if (i13 == i16 || i14 == i16 || i15 == i16||!ok(list, i9, i10, i12, i16))continue;
			if (!ok(list, i10, i15, i16, 16) || list[i12][3] + list[i16][2] != 10)continue;
			cout << "    " << setw(4) << i1 + 1 << setw(4) << i2 + 1 << setw(4) << i13 + 1 << endl << setw(4) << i3 + 1;
			cout << setw(4) << i4 + 1 << setw(4) << i5 + 1 << setw(4) << i6 + 1 << setw(4) << i14 + 1 << endl;
			cout << setw(4) << i7 + 1 << setw(4) << i8 + 1 << setw(4) << i9 + 1 << setw(4) << i10 + 1 << setw(4);
			cout << i15 + 1 << endl << "    " << setw(4) << i11 + 1 << setw(4) << i12 + 1 << setw(4) << i16 + 1 ;
			cout << endl << endl << "这是其中一种解法,数字1的位置表示第一个输入的格子应该排的位置,以此类推" << endl;
			system("pause>nul");
			return true;
		}
	}
	return false;
}
程序内部编号:(4个角落的编号为16)



运行结果:


对应答案:


### VSCode中的颜色方块配置 在VSCode中,颜色方块通常用于直观地表示各种界面元素的颜色属性。对于源代码控制(SCM)部分的颜色配置,可以通过`scm.providerBorder`来定义SCM提供者分隔符边框的颜色[^1]。 针对终端内的ANSI颜色编码,例如想要自定义错误信息前缀如`npm ERR!`的颜色,则可以调整`terminal.ansiWhite`等相关设置项。不过需要注意的是,这里的例子提到的颜色值并非白色而是特定的一种粉色(`#db0686`),这表明该设置可能被用来覆盖默认的白颜色以提高可见度或满足个性化需求[^2]。 为了实现更加丰富的颜色方块显示效果,在VSCode中还可以利用扩展插件或是编辑器自身的主题定制能力来进行深入配置。具体来说: - **安装并启用支持颜色预览的扩展**:一些社区开发的插件能够增强VSCode处理色彩的能力,允许用户直接在编辑区内查看颜色样本。 - **创建或应用带有特殊颜色方案的主题**:通过更改当前使用的视觉主题,可以获得不同的UI组件着色风格,包括但不限于侧栏、状态栏以及编辑区域内的语法高亮等。 #### 使用Markdown和HTML样式嵌入颜色方块 当编写文档或者注释时,可以在Markdown文件里加入内联CSS样式的HTML标签来呈现固定尺寸的颜色矩形作为示意: ```html <span style="display:inline-block;width:1em;height:1em;background-color:#ffcc00;"></span> ``` 这段代码会在渲染后的页面上显示出一个黄色的小正方形。当然,实际项目中建议遵循官方推荐的方法去管理配色方案,而不是硬编码这些细节到源码之中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值