百炼OJ 2801:填词

2801:填词

总时间限制: 
1000ms 
内存限制: 
65536kB
描述
Alex喜欢填词游戏。填词是游戏是一个非常简单的游戏。填词游戏包括一个N * M大小的矩形方格盘和P个单词。玩家需要把每个方格中填上一个字母使得每个单词都能在方格盘上找到。每个单词都能找到要满足下面的条件:

每个方格都不能同时属于超过一个的单词。一个长为k的单词一定要占据k个方格。单词在方格盘中出现的方向只能是竖直的或者水平的。

你的任务是首先在方格盘上找到所有的单词,当然在棋盘上可能有些方格没有被单词占据。然后把这些没有用的方格找出来,把这些方格上的字母按照字典序组成一个“神秘单词”。

如果你还不了解规则,我们可以具一个例子,比如在下图中寻找单词BEG和GEE。
输入
输入的第一行包括三个整数N,M和P (2 <= M, N <= 10, 0 <= P <=100)。接下来的N行,每行包括M个字符,来表示方格盘。接下来P行给出需要在方格盘中找到的单词。

输入保证填词游戏至少有一组答案。

输入中给出的字母都是大写字母。
输出
输出“神秘单词”,注意“神秘单词”中的字母要按照字典序给出。
样例输入
3 3 2
EBG
GEE
EGE
BEG
GEE
样例输出
EEG
来源
翻译自Northeastern Europe 2001, Northern Subregion的题目

不用考虑是怎么填的,只要知道字母不能重复使用就行了。就是统计字符。这题如果一个一个字符地读会超时。TLE了一次。
#include <stdio.h>
#include <string.h>
int ch[27] = {0}, m, n, p;
int main()
{
    int i, j;
    char c, word[101];
    scanf("%d%d%d", &m, &n, &p);
    getchar();
    for (i = 0; i < m; i ++)
    {
        scanf("%s", word);
        for(j = 0; j < n; j ++)
        {
            ch[word[j]-'A'] ++;
        }
    }
    for (i = 0; i < p; i ++)
    {
        scanf("%s", word);
        int slen = strlen(word);
        for(j = 0; j < slen; j ++)
        {
            ch[word[j]-'A'] --;
        }
    }
    for (i = 0; i < 26; i ++)
    {
        while(ch[i] > 0)
        {
            printf("%c", i + 'A');
            ch[i] --;
        }
    }
    printf("\n");
    return 0;
}



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值