思维——Nastya and Scoreboard

编程入门 行业动态 更新时间:2024-10-26 04:27:49

<a href=https://www.elefans.com/category/jswz/34/1770010.html style=思维——Nastya and Scoreboard"/>

思维——Nastya and Scoreboard

传送门

题解:
定义 f ( i , j ) f(i,j) f(i,j)函数搜索到第i个字符的时候使用了j根木棍。我们可以将题目中的10个字符串全部转换成十进制,然后因为我们要想办法变成这10个数字,所以我们从大到小搜索过去,并且记录已经搜索的情况进行剪纸。

#include <bits/stdc++.h>
//#define int long long
using namespace std;
int tab[]={119,18,93,91,58,107,111,82,127,123};
int f[2005][2005],n,k,a[2005],res[2005];
int work(int x)
{int res=0;for(int i=7;i>=0;i--){if(x>>i&1) res++;}return res;
}
void dfs(int x,int us)
{if(f[x][us]||us>k) return ;f[x][us]=1;if(x==n+1){if(us==k){for(int i=1;i<=n;i++) printf("%d",res[i]);exit(0);}return;}for(int i=9;i>=0;i--){res[x]=i;if((tab[i]&a[x])==a[x]) dfs(x+1,us+work(a[x]^tab[i]));}
}
signed main()
{string s;scanf("%d%d",&n,&k);for(int i=1;i<=n;i++){cin>>s;for(int j=0;j<s.length();j++){a[i]=(a[i]<<1)+(s[j]-'0');}}dfs(1,0);puts("-1");
}

更多推荐

思维——Nastya and Scoreboard

本文发布于:2024-02-12 17:01:24,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1688661.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:思维   Nastya   Scoreboard

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!