usaco2.24Party Lamps

乱七八糟的写 改着改着就这么过了。。dfs枚举 可以看出每个串前六位跟后面的都是一样的 比较不同也就看前6位就可以了

/*
    ID: your_id_here
    PROG: lamps
    LANG: C++
*/
#include <iostream>
#include<cstdio>
#include<stdlib.h>
#include<algorithm>
#include<cstring>
using namespace std;
int f[10],n,c,on[110],of[110],g1,g2;
char str[110],ss[110],si[1000][10],w;
int Comp(const void *p1,const void *p2)
{
   return strcmp((char *)p1,(char *)p2);
}
int judge(char *sw)
{
    int i;
    for(i = 1 ; i <= g1 ; i++)
    {
        if(sw[(on[i]-1+6)%6]=='0')
        return 0;
    }
     for(i = 1 ; i <= g2 ; i++)
    {
        if(sw[(of[i]-1+6)%6]=='1')
           return 0;
    }
    return 1;
}
void dfs(int x,int k)
{
    int i,j,ff =0;
    char sj[110];
    switch(x)
    {
        case 1:
        for(i = 0 ; i < 6 ; i++)
        if(str[i]=='0')
           str[i] = '1';
        else
           str[i] = '0';break;
        case 2:
        for(i = 0 ; i < 6 ; i++)
        {
            if((i+1)%2!=0)
            {
                 if(str[i]=='0')
                 str[i] = '1';
                 else
                 str[i] = '0';
            }
        }
        break;
        case 3:
        for(i = 0 ; i < 6 ; i++)
        {
            if((i+1)%2==0)
            {
                 if(str[i]=='0')
                 str[i] = '1';
                 else
                 str[i] = '0';
            }
        }
        break;
        case 4:
        for(i = 0 ; i < 6 ; i++)
        {
            if(((i+1)-1)%3==0)
            {
                 if(str[i]=='0')
                 str[i] = '1';
                 else
                 str[i] = '0';
            }
        }
        break;
    }
    if(k==c)
    {

        for(i = 0 ; i < w ; i++)
        {
            if(strcmp(str,si[i])==0)
                return ;
        }
        if(!judge(str))
        return ;
        strcpy(si[w],str);
        w++;
        return ;
    }
    for(j = 0 ; j < 6 ;j++)
       sj[j] = str[j];
    for(i = 1; i <= 4 ; i++)
    {
        for(j = 0 ; j < 6 ;j++)
        str[j] = sj[j];
        f[i] =1 ;
        dfs(i,k+1);
    }
}
int main()
{
    freopen("lamps.in","r",stdin);
    freopen("lamps.out","w",stdout);
    int i,j,k,x;
    cin>>n>>c;
    while(cin>>x)
    {
        if(x==-1)
            break;
        g1++;
        on[g1] = x;
    }
    while(cin>>x)
    {
        if(x==-1)
            break;
        g2++;
        of[g2] = x;
    }
    for(i = 0 ; i < n ; i++)
        ss[i] = '1';
    if(c==0)
    {
        if(judge(ss))
        puts(ss);
        else
        puts("IMPOSSIBLE");
        return 0;
    }
    if(c>4)
    c = 4;
    for(i = 1; i <= 4 ; i++)
    {
        for(j = 0 ; j < 6 ;j++)
            str[j] = ss[j];
        dfs(i,1);
    }
    if(w==0)
    {
         puts("IMPOSSIBLE");
         return 0;
    }
    qsort(si,w,sizeof(si[0]),Comp);
    for(i = 0 ; i < w  ; i++)
    {
        for(j = 1 ; j <= n/6 ; j++)
            cout<<si[i];
        for(j = 1 ; j <= n%6 ; j++)
            cout<<si[i][j-1];
        puts("");
    }
    fclose(stdin);
    fclose(stdout);
    return 0;
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于Springboot+Vue的智慧养老服务管理系统源码+项目使用说明(优秀毕业设计).zip 该项目属于个人毕业设计,经导师的精心指导与严格评审获得高分通过的设计项目。主要针对计算机相关专业的教师、正在做毕设、课设的学生使用,也可作为项目实战演练,可直接作为课程设计、期末大作业、毕设等。 1.项目代码功能经验证ok,确保稳定可靠运行。欢迎下载使用!在使用过程中,如有问题或建议,请及时私信沟通。 2.主要针对各个计算机相关专业,包括计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师或企业员工使用。 3.项目具有丰富的拓展空间,不仅可作为入门进阶,也可直接作为毕设、课程设计、大作业、初期项目立项演示等用途。 4.当然也鼓励大家基于此进行二次开发。 5.期待你能在项目中找到乐趣和灵感,也欢迎你的分享和反馈! 介绍 随着人口老龄化趋势的加剧,老年人口比例不断增加,传统的养老服务模式已经难以满足现代老年人的多元化需求。因此,如何高效、精准地提供养老服务,成为了社会关注的焦点。信息化与智能化的发展为养老服务带来了新的机遇。智慧养老作为新兴的养老服务模式,正逐步改变传统的养老服务格局。 #### 安装教程 1. 运行环境准备mysql8+java8+npm14.16.1 2. 配置maven路径,加载依赖 3. 运行sql文件,确保application.yml的数据库名称和账号密码是数据库所在主机的账号密码 #### 使用说明 1. 登入 账号:admin 密码:admin 账号:user 密码:123456 2.运行流程 前端初始化指令: > npm install 前端运行指令(有两个端,一个是管理端,一个是用户端): > npm run serve #### 项目演示 + 普通用户 访问者可以在最顶端看到系统的导航栏,根据自己的需求点击需要去到的页面。用户可以单击“入院指南”,在入院指南界面的输入框中输入标题并进行搜索,就可以查看标题、发布时间、注意事项、发布人、封面等其他信息,在个人中心界面中,可以看见家属的账号、密码和性别等基本信息,还可以对这些信息进行更新操作。 ![GIF 2024-6-17 19-49-40](GIF 2024-6-17 19-49-40-1718630421956.gif) + 管理员 管理员单击家属管理,在家属管理页面中输入家属的各项信息后,在页面中进行查询、新增或删除家属信息等操作。管理员点击护工管理,在护工管理页面中输入护工的所有信息,然后在页面上可以点击详情来查看护工的详细情况,点击修改来修改护工的信息,点击删除来删除护工的信息。管理员单击房间资料管理,在这个页面中可以对房间资料的信息进行管理。管理员单击床位管理,可以查看房间号、楼房名称等各项信息,还可以点击修改来修改床位信息,点击删除来删除床位信息。管理员还可以对老人入住进行管理,在这个界面中可以查看像入住编号、老人年龄等老人入住的详细信息,可以在界面顶端输入具体信息来查找,还可以点击删除来进行删除操作。管理员单击外出报备管理,在外出报备管理界面中可以查看老人的外出报备情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值