纵横字谜的答案(Crossword Answers, ACM/ICPC World Finals 1994, UVa232)原题链接

原题链接
主要题意呢就是竞赛书上的那个意思,输入输出格式看一下原题链接就行了
先输入c,r接着给出c行r列的表

#include<bits/stdc++.h>

using namespace std;

char a[10][10];
int judge[10][10];

int main()
{
	int c, r;
	int sum = 1;
	while (1)
	{
		
		cin >> c >> r;
		if (c = 0)
			break;
		cin >> c >> r;
		for (int i = 0; i < c; i++)
			for (int j = 0; j < r; j++)
			{
				cin >> a[i][j];
				if (a[i][j] == '*')
					judge[i][j] = -1;
			}
		int ans = 1;
		for (int i = 0; i < c; i++)
			for (int j = 0; j < r; j++)
			{
				if ((i == 0 || j == 0) && judge[i][j] != -1)
					judge[i][j] = ans;
				ans++;
			}
		cout << "puzzle #" << sum << endl;
		cout << "Across" << endl;
		for(int i=0;i<c;i++)
			for (int j = 0; j < r; j++)
			{
				for (int k = j; k < r; k++)
				{
					if (judge[i][j] == -1)
						break;
					else
					{
						if (k == j)
							cout << "	" << judge[i][k] << ".";
						cout << a[i][k];
					}
					if (k == r - 1)
						cout << endl;
				}
				
			}
		for (int i = 0; i < r; i++)
			for (int j = 0; j < c; j++)
			{
				for (int k = j; k < c; k++)
				{
					if (judge[i][j] == -1)
						break;
					else
					{
						if (k == j)
							cout << "	" << judge[k][i] << ".";
						cout << a[k][i];
					}
					if (k == c - 1)
						cout << endl;
				}

			}

		sum++;
	}
	

}

这是我自己写的,可能不对呜呜

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疯狂的码泰君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值