2022寒假集训day3
day3:四道检测题,花了大半天时间。
T1
子集和问题
问题描述
子集和问题的一个实例为<S,c>。其中S={x1,x2,…,xn}是一个正整数的集合,c是一个正整数。子集和问题判定是否存在S的一个子集S1,使得S1中所有元素的和为c
找不到原题了
#include <bits/stdc++.h>
using namespace std;
int n,a[10000000],b[10000000];
int m,i,k=1,s=0;
bool f[10000000];
void print(int k)
{
for (i=1;i<=k;++i)cout<<b[i]<<" ";
exit(0);
} void search(int k,int s,int m)
{
int i;
if (s>m)return;
if (k>n){cout<<"No Solution!";exit(0);}
for (i=1;i<=n;++i)
if (f[i])
{
f[i]=false;
s=s+a[i];
b[k]=a[i];
if (s==m){print(k);}
else search(k+1,s,m);
s=s-a[i];
f[i]=true;
b[k]=0;
}
return ;
} int main()
{
cin>>n; cin>>m;
for (i=1;i<=n;++i)
cin>>a[i];
for (i=1;i<=n;++i)
f[i]=true;
search(k,s,m);
return 0;
}
坑很多啊,除了不要忘记无解,而且No,Solution的S 也需要大写,就无语。硬是卡了很长时间,去做后面的题
这道题大体就是对集合的整体先搜索一遍,然后选取某几个元素与定值相等,并输出这几个元素。
————————————————————————————————————————
T2
工作分配问题
设有n件工作分配给n个人。将工作i分配给第j个人所需的费用为 c i j c_{ij} cij。试设计一个算法,为每一个人都分配1件不同的工作,并使总费用达到最小。
设计一个算法,对于给定的工作费用,计算最佳工作分配方案,使总费用达到最小。
Input
输入数据的第一行有1 个正整数n (1≤n≤20)。接下来的n行,每行n个数,表示工作费用。
Output
将计算出的最小总费用输出。
#include <bits/stdc++.h>
using namespace std;
#define N 1000
int cost[N][N];
int b[N]={0};
int n;
int sum;
void search(int i,int c)
{
if(c>sum) return;
if(i==n) {
if(c<sum) sum=c;
return;
}
for(int j=0;j<n;j++) {
if(b[j]==0) {
b[j]=1;
search(i+1,c+cost[i][j]);
b[j]=0;
}
}
} int main()
{
cin>>n;
for(int i=0;i<n;i++) {
for(int j=0;j<n;j++) {
cin>>cost[i][j];
}
}
sum = N;
search(0,0);
cout<<sum;
return 0;
}
T2就是我写起来相对得心应手的一题了,在T1上死磕之后看到它显得无比亲切。
虽然之前做过类似的,整体思路还算清楚,写起来也还是有些犹豫。尤其是中间的search,和T1的不同,而是类似全部枚举再进行比较。
————————————————————————————————————————
T3
装载问题
题目描述
有一批共 n 个集装箱要装上艘载重量为 c 的轮船,其中集装箱 i 的重量为 wi 。找出一种最优装载方案,将轮船尽可能装满,即在装载体积不受限制的情况下,将尽可能重的集装箱装上轮船。
输入
第一行有2个正整数n和c。n是集装箱数,c是轮船的载重量。第2行中有n个正整数,表示集装箱的重量(0<n<10000,0<c<32767)。
输出
计算出的最大装载重量输出。
#include<bits/stdc++.h>
using namespace std;
int maxx,ans,n,c,sz[10000];
void search(int i,int k=0) {
if(maxx>c) return ;
if(k==i+1) {
ans=max(ans,maxx);
return ;
}
if(maxx+sz[k]<=c) {
maxx+=sz[k];
search(i,k+1);
maxx-=sz[k];
}
search(i,k+1);
}
int main() {
cin>>n>>c;
for(int i=1; i<=n; i++)
cin>>sz[i];
sort(sz+1,sz+n+1);
search(n);
cout<<ans<<endl;
return 0;
}
困扰了很长时间,虽是第三题但却是最后一个做出来的。
尽可能的去寻找最大的重量使船尽可能的装满。
首先读题不仔细,应该把整道题全部读懂并且有具体思路之后在写代码,而不是边想边写,会使效率低下,并且一直困扰在一个位置。
————————————————————————————————————————
T4
字符序列
从三个元素的集合[A,B,C]中选取元素生成一个N个字符组成的序列,使得没有两个相邻字的子序列(子序列长度=2)相同。例:N = 5时ABCBA是合格的,而序列ABCBC与ABABC是不合格的,因为其中子序列BC,AB是相同的。
对于由键盘输入的N(1<=N<=12),求出满足条件的N个字符的所有序列和其总数。
测试数据:
输入:4
输出:72
#include <bits/stdc++.h>
using namespace std; int n,sum=0;
int ans[15];
bool pd()
{
int cnt=0;
for(int i=3; i<=n; i++)
{
if(ans[i]==ans[i-2])
cnt++;
else cnt=0; if(cnt==2)
return 0;
}
return 1;
}
void dfs(int x)
{
if(x==n+1)
{
if(pd())
sum++;
return;
}
for(int i=1;i<=3;i++)
{
ans[x]=i;
dfs(x+1);
}
}
int main()
{ scanf("%d",&n);
dfs(1);
printf("%d",sum);
return 0;;
}
前面一直在用search,这道就换成深搜了。
思路还算清晰,很快就qie掉了。
本日总结:
search掌握不算太熟练,做题分析不到位,细节浪费很长时间。
对一些算法也进行了强化,但还是有所欠缺,多加练习。
2022寒假集训day3的更多相关文章
- 2022寒假集训day2
day1:学习seach和回溯,初步了解. day2:深度优化搜索 T1 洛谷P157:https://www.luogu.com.cn/problem/P1157 题目描述 排列与组合是常用的数学方 ...
- HZNU-ACM寒假集训Day3小结 搜索
简单搜索 1.DFS UVA 548 树 1.可以用数组方式实现二叉树,在申请结点时仍用“动态化静态”的思想,写newnode函数 2.给定二叉树的中序遍历和后序遍历,可以构造出这棵二叉树,方法是根据 ...
- 2022寒假集训day6
day6上午还是做四道题T1区域[上机练习]1.编程计算由"*"号围成的下列图形的面积.面积计算方法是统计*号所围成的闭合曲线中水平线和垂直线交点的数目.如下图所示,在 10*10 ...
- 2022寒假集训day5
day5 五道栈的题加上字符串. 单调队列. T1 表达式括号匹配 洛谷P1739 题目描述 假设一个表达式有英文字母(小写).运算符(+,-,*,/)和左右小(圆)括号构成,以"@&q ...
- 2022寒假集训day4
day4(day5补完的) 继续刷搜索方面的题, 初步了解了序列. T1 迷宫问题 题目描述设有一个 n*n 方格的迷宫,入口和出口分别在左上角和右上角.迷宫格子中分别放 0 和 1 ,0 表示可通, ...
- 【LOJ6067】【2017 山东一轮集训 Day3】第三题 FFT
[LOJ6067][2017 山东一轮集训 Day3]第三题 FFT 题目大意 给你 \(n,b,c,d,e,a_0,a_1,\ldots,a_{n-1}\),定义 \[ \begin{align} ...
- 【LOJ#6066】「2017 山东一轮集训 Day3」第二题(哈希,二分)
[LOJ#6066]「2017 山东一轮集训 Day3」第二题(哈希,二分) 题面 LOJ 题解 要哈希是很显然的,那么就考虑哈希什么... 要找一个东西可以表示一棵树,所以我们找到了括号序列. 那么 ...
- CSU-ACM寒假集训选拔-入门题
CSU-ACM寒假集训选拔-入门题 仅选择部分有价值的题 J(2165): 时间旅行 Description 假设 Bobo 位于时间轴(数轴)上 t0 点,他要使用时间机器回到区间 (0, h] 中 ...
- 2019暑期金华集训 Day3 字符串
自闭集训 Day3 字符串 SAM 考虑后缀树. SAM的parent树是反串的后缀树,所以后面加一个字符的时候相当于往串前面加一个字符,恰好多出了一个后缀. 于是可以以此来理解SAM. 每一条路径对 ...
随机推荐
- ClickHouse在监控系统中的应用
一.背景 这个项目是一个监控系统,主要监控主机.网络设备.应用等.主机监控的数量有1500台左右,数量还在不断增长,加上网络设备和应用,目前总共监控的指标达到近40万个. 二.问题 一开始为了快速交付 ...
- cpu负载
查看cpu负载,我们经常会使用top,或者是uptime命令 但是这只能看到cpu的总体的负载情况.如果我们想看cpu每个核心的负载情况是看不到的. 所以我们可以用mpstat命令 服务器一共32核心 ...
- CSS基础 列表相关的属性的使用
1.无序列表:就是不需要排列顺序的情况,用无序列表 语法结构:<ul> <li></li> <li></li> </ul> 特点 ...
- java 方法 compareTo()的正确使用
总结:(1)如果比较的是数字 则结果大于则为1 等于则为0 小于则为-1(2)如果比较的是字符[串] 则按照从左到右排序找对应不一样的字符第一个字符, 然后将字符装对应的ASCLL码数字,做减法运算, ...
- Mysql高性能优化
一.背景 最近公司项目添加新功能,上线后发现有些功能的列表查询时间很久.原因是新功能用到旧功能的接口,而这些旧接口的 SQL 查询语句关联5,6张表且编写不够规范,导致 MySQL 在执行 SQL 语 ...
- 微信小程序输入框上移问题解决
微信小程序的输入框在上面还好,如果不是,在聚焦的时候页面就会上移,上方的页面信息会看不到,影响用户操作 在这里可以手动设置并获取输入框的高度来解决 这种方式虽然有的机子有点卡,但是已经算是比较完美的解 ...
- 使用.NET 6开发TodoList应用(28)——实现应用程序健康检查
系列导航及源代码 使用.NET 6开发TodoList应用文章索引 需求 应用健康检查在容器部署的微服务场景下非常常见,相比而言单体非容器部署的应用就不太关心这个特性,为了后续的内容我们在本文中简单介 ...
- 链式printf()函数的用法
printf()函数:十进制格式型输出函数. #include <stdio.h> int printf( const char *format, ... ); 1.首先printf的返回 ...
- 性能优化-使用双buffer实现无锁队列
借助本文,实现一种在"读多写一"场景下的无锁实现方式 在我们的工作中,多线程编程是一件太稀松平常的事.在多线程环境下操作一个变量或者一块缓存,如果不对其操作加以限制,轻则变量值或者 ...
- vue3路由的使用,保证你有所收获!
路由变量 有的小伙伴,可能是第一次听见路由变量这个词. 什么是路由变量了,顾名思义就是这个路由地址是动态的,不是固定的. 它的运用场景是哪里呢? 比如说:1.详情页的地址,我们就可以去使用路由变量. ...