UVa387 - A Puzzling Problem

原创 2012年03月26日 18:11:35
#include <stdio.h>
#include <string.h>

#define MAX 16
#define N 4

typedef struct node {
    int shape[N][N];
    int startx, starty;
    int row, col;
} node;

node inode[MAX];
int shapenum;
int vis[N][N];

int dfs(int cur, int v[][N]);
int is_vis(int v[][N], int i, int j, int m, int n, int startx, int starty);

int main()
{
    int n;
    int row, col;
    int i, j;
    char ch;
    int first;
    int iCase = 0;

#ifndef ONLINE_JUDGE
    freopen("d:\\UVa\\uva_in.txt", "r", stdin);
    /*freopen("d:\\UVa\\uva_out.txt", "w", stdout);*/
#endif

    while (scanf("%d", &n) && n != 0) {
        shapenum = 0;
        memset(vis, 0, sizeof(vis));
        memset(inode, 0, sizeof(inode));
        while (n--) {
            scanf("%d%d", &row, &col);
            inode[shapenum].row = row;
            inode[shapenum].col = col;
            getchar();
            first = 1;
            for (i = 0; i < row; i++) {
                for (j = 0; j < col; j++) {
                    scanf("%c", &ch);
                    if (ch == '1') {
                        inode[shapenum].shape[i][j] = 1;
                        if (first) {
                            inode[shapenum].startx = i;
                            inode[shapenum].starty = j;
                            first = 0;
                        }
                    } else
                        inode[shapenum].shape[i][j] = 0;
                }
                getchar();
            }

#ifndef ONLINE_JUDGE
            for (i = 0; i < row; i++) {
                for (j = 0; j < col; j++)
                    printf("%d ", inode[shapenum].shape[i][j]);
                printf("\n");
            }
            printf("\n");
#endif
            shapenum++;
        }
        /*printf("shapenum=%d\n", shapenum);*/
        if (iCase++)
        	printf("\n");
        if (dfs(0, vis))
            ;
        else
            printf("No solution possible\n");
    }

    return 0;
}

int dfs(int cur, int v[][N])
{
    int i, j;
    int temp[N][N];
    int m, n;
    int ok;
    int row, col;
    int startx, starty;

    if (cur == shapenum) {
        for (i = 0; i < N; i++) {
            for (j = 0; j < N; j++) {
                if (!v[i][j])
                    return 0;
            }
        }

        for (i = 0; i < N; i++) {
            for (j = 0; j < N; j++) {
                printf("%d", v[i][j]);
            }
            printf("\n");
        }
        return 1;
    }

    row = inode[cur].row;
    col = inode[cur].col;
    startx = inode[cur].startx;
    starty = inode[cur].starty;
    /*memcpy(temp, v, sizeof(int) * N * N);*/



    for (i = 0; i < N; i++) {
        for (j = 0; j < N; j++) {
            memcpy(temp, v, sizeof(int) * N * N);
            if (!temp[i][j]) {
                ok = 1;
                for (m = 0; m < row && ok; m++) {
                    for (n = 0; n < col && ok; n++) {
                        if (inode[cur].shape[m][n]) {
                            if (is_vis(temp, i, j, m, n, startx, starty) == 0)
                                ok = 0;
                        }
                    }
                }

                if (ok) {
                    for (m = 0; m < row; m++) {
                        for (n = 0; n < col; n++) {
                            if (inode[cur].shape[m][n])
                                temp[i + m - startx][j + n - starty] = cur + 1;
                        }
                    }
#ifndef ONLINE_JUDGE
                    for (i = 0; i < N; i++) {
                        for (j = 0; j < N; j++) {
                            printf("%d ", temp[i][j]);
                        }
                        printf("\n");
                    }
                    printf("\n");
#endif

                    if (dfs(cur + 1, temp))
                        return 1;

#ifndef ONLINE_JUDGE
                    for (m = 0; m < N; m++) {
                        for (n = 0; n < N; n++) {
                            if (temp[i + m - startx][j + n - starty] == cur + 1)
                                temp[m][n] = 0;;
                        }
                    }
#endif

                }

            }
        }
    }
    return 0;

}

int is_vis(int v[][N], int i, int j, int m, int n, int startx, int starty)
{
    if (i + m - startx >= N || i + m - startx < 0 || j + n - starty >= N || j + n - starty < 0 || v[i + m - startx][j + n - starty])
        return 0;
    return 1;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

算法导论(第三版)-复习- Stable Matching Problem

稳定婚姻算法 - Gale-Shapley算法
  • ZoeyyeoZ
  • ZoeyyeoZ
  • 2016年07月01日 17:05
  • 1213

【网络流+可持久化线段树】[UOJ#77/BZOJ3218]A+B Problem

题目题目链接UOJ#77 BZOJ3218题目描述 分析感谢VFleaKing的博客中的讲解和geng4512的博客中的代码,涨了不少知识。网络流的做法首先我们来看看答案是怎么得到的 ans=∑...
  • outer_form
  • outer_form
  • 2016年03月10日 16:03
  • 1236

Python深入:编码问题总结

一:字符编码简介          1:ASCII          最初的计算机的使用是在美国,所用到的字符也就是现在键盘上的一些符号和少数儿个特殊的符号,一个字节所就能足以容纳所有的这些字符,实际...
  • gqtcgq
  • gqtcgq
  • 2015年07月26日 16:15
  • 5185

第14周Problem C: 杨辉三角形

问题及代码: /* *Copyright (c)2014,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:number.cpp *作 者:单昕昕 ...
  • MIKASA3
  • MIKASA3
  • 2014年11月27日 15:57
  • 655

524 A-B Problem【字符串处理】

A-B Problem 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描述 A+B问题早已经被大家所熟知了,是不是很无聊呢?现在大家来做一下A-B吧。 现在有两...
  • liuke19950717
  • liuke19950717
  • 2015年09月02日 11:46
  • 332

Problem D: 数组类(II)

Description 封装一个模板数组类,用于存储数组和处理的相关功能,支持以下操作: 1. Array::Array(int l)构造方法:创建一个长度为l的组对象。 2. Arra...
  • qq_38158040
  • qq_38158040
  • 2017年04月19日 08:55
  • 396

【安卓学习之常见问题】 使用Eclipse clean时,出现“cleaning all project has encountered a problem”提示

在使用Eclipse时,经常需要clean下工程,结果每次clean都提示:“cleaning all project has encountered a problem. Errors occurr...
  • ljb568838953
  • ljb568838953
  • 2016年09月18日 09:19
  • 3368

Problem F: C语言习题 矩阵元素变换

能测试中,如有问题请联系17862809558 17862818011 18865513850 18865513930 Problem F: C语言习题 矩阵元素变换 Time Lim...
  • wzy_112099
  • wzy_112099
  • 2016年03月10日 21:28
  • 248

HDU 2601An easy problem-素数的运用,暴力求解

An easy problem Time Limit: 3000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & %...
  • qq_18661257
  • qq_18661257
  • 2015年07月28日 11:57
  • 965

极光推送的使用

极光推送的使用
  • zhangying1994
  • zhangying1994
  • 2016年07月03日 14:30
  • 1596
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:UVa387 - A Puzzling Problem
举报原因:
原因补充:

(最多只允许输入30个字)