uva-387-暴力枚举

题意:

给你一些小方块,问是不是能组成一个4X4的大方块,所有方块全部要使用,裸枚举

#include <iostream>
#include <stdio.h>
#include <memory.h>

using namespace std;
const int NN = 20;
class Piece
{
    private:
        int r;
        int c;
        int** p;
    public:
        Piece()
                : r(0), c(0)
        {
            p = NULL;
        }
        Piece(int r, int c, int (*pp)[NN])
        {
            this->r = r;
            this->c = c;
            this->p = new int*[r];

            for(int i = 0; i < r; i++)
            {
                this->p[i] = new int[c];
                memcpy(this->p[i], pp[i], c * sizeof(int));
            }
        }
        ~Piece()
        {
            for(int i = 0; i < r; i++)
                delete[] p[i];
            delete this->p;
        }
        int getR()
        {
            return this->r;
        }
        int getC()
        {
            return this->c;
        }
        int ** getP()
        {
            return this->p;
        }

};

int N;
int r, c;
int m[6][6];
int vis[NN];
Piece* piece[NN];
int pi = 0;
void dump()
{
    for(int i = 0; i < pi; i++)
        for(int j = 0; j < piece[i]->getR(); j++)
        {
            for(int k = 0; k < piece[i]->getC(); k++)
                cout << piece[i]->getP()[j][k];
            cout << endl;
        }
}
bool judge(int y, int x, Piece* p)
{
    for(int i = 0; i < p->getR(); i++)
        for(int j = 0; j < p->getC(); j++)
            if(p->getP()[i][j] != 0 && m[i + y][x + j] != 0)
            {
                return false;
            }
    return true;
}
void reset(int x, int y, int r, int c, int cur)
{
    for(int i = 0; i < r; i++)
        for(int j = 0; j < c; j++)
        {
            if(m[y + i][x + j] != cur)
                continue;
            m[y + i][x + j] = 0;
        }
}

void copy(int x, int y, int r, int c, int** src)
{
    for(int i = 0; i < r; i++)
        for(int j = 0; j < c; j++)
        {
            if(m[y + i][x + j])
                continue;
            m[y + i][x + j] = src[i][j];
        }
}
bool dfs(int cur)
{
    if(cur == pi)
    {
        for(int i = 0; i < 4; i++)
        {
            for(int j = 0; j < 4; j++)
                if(m[i][j] == 0)
                    return false;
        }
        return true;
    }
    //对当前的cur,枚举每一个坐标X,Y
    for(int i = 0; i < 4; i++)
    {
        for(int j = 0; j < 4; j++)
        {
            if(m[i][j] && (piece[cur]->getP()[0][0]))
                continue;
            if(!judge(i, j, piece[cur]))
                continue;
            int r = piece[cur]->getR();
            int c = piece[cur]->getC();
            copy(j, i, r, c, piece[cur]->getP());
            int ok = dfs(cur + 1);
            if(ok)
                return ok;
            reset(j, i, r, c, cur + 1);
        }
    }
    return false;
}
int main()
{
    //freopen("d://1.text", "r", stdin);
    int t = 0;
    while (cin >> N && N)
    {
        if(t != 0)
            cout << endl;
        ++t;
        memset(m, 0, sizeof(m));
        memset(piece, 0, sizeof(piece));
        memset(vis, 0, sizeof(vis));
        int p[NN][NN];
        pi = 0;
        for(int i = 1; i <= N; i++)
        {
            scanf("%d %d", &r, &c);
            for(int j = 0; j < r; j++)
                for(int k = 0; k < c; k++)
                {
                    char t;
                    cin >> t;
                    if(t == '0')
                        p[j][k] = 0;
                    else
                        p[j][k] = i;
                }
            Piece* pp = new Piece(r, c, p);
            piece[pi++] = pp;
        }
        bool ok = dfs(0);
        if(!ok)
        {
            cout << "No solution possible" << endl;
        }
        else
        {
            for(int i = 0; i < 4; i++)
            {
                for(int j = 0; j < 4; j++)
                    cout << m[i][j];
                cout << endl;
            }
        }
    }
//    dump();

    return 0;
}

 

posted on 2018-06-24 18:41 好吧,就是菜菜 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/shuiyonglewodezzzzz/p/9221362.html

本课题设计了一种利用Matlab平台开发的植物叶片健康状态识别方案,重点融合了色彩与纹理双重特征以实现对叶片病害的自动化判别。该系统构建了直观的图形操作界面,便于用户提交叶片影像并快速获得分析结论。Matlab作为具备高效数值计算与数据处理能力的工具,在图像分析与模式分类领域应用广泛,本项目正是借助其功能解决农业病害监测的实际问题。 在色彩特征分析方面,叶片影像的颜色分布常与其生理状态密切相关。通常,健康的叶片呈现绿色,而出现黄化、褐变等异常色彩往往指示病害或虫害的发生。Matlab提供了一系列图像处理函数,例如可通过色彩空间转换与直方图统计来量化颜色属性。通过计算各颜色通道的统计参数(如均值、标准差及主成分等),能够提取具有判别力的色彩特征,从而为不同病害类别的区分提供依据。 纹理特征则用于描述叶片表面的微观结构与形态变化,如病斑、皱缩或裂纹等。Matlab中的灰度共生矩阵计算函数可用于提取对比度、均匀性、相关性等纹理指标。此外,局部二值模式与Gabor滤波等方法也能从多尺度刻画纹理细节,进一步增强病害识别的鲁棒性。 系统的人机交互界面基于Matlab的图形用户界面开发环境实现。用户可通过该界面上传待检图像,系统将自动执行图像预处理、特征抽取与分类判断。采用的分类模型包括支持向量机、决策树等机器学习方法,通过对已标注样本的训练,模型能够依据新图像的特征向量预测其所属的病害类别。 此类课题设计有助于深化对Matlab编程、图像处理技术与模式识别原理的理解。通过完整实现从特征提取到分类决策的流程,学生能够将理论知识与实际应用相结合,提升解决复杂工程问题的能力。总体而言,该叶片病害检测系统涵盖了图像分析、特征融合、分类算法及界面开发等多个技术环节,为学习与掌握基于Matlab的智能检测技术提供了综合性实践案例。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值