笔试强训Day14Day15

T1:幸运的袋子

链接:幸运的袋子__牛客网 (nowcoder.com)

题目描述:
一个袋子里面有n个球,每个球上面都有一个号码(拥有相同号码的球是无区别的)。如果一个袋子是幸运的当且仅当所有球的号码的和大于所有球的号码的积。
例如:如果袋子里面的球的号码是{1, 1, 2, 3},这个袋子就是幸运的,因为1 + 1 + 2 + 3 > 1 * 1 * 2 * 3
你可以适当从袋子里移除一些球(可以移除0个,但是别移除完),要使移除后的袋子是幸运的。现在让你编程计算一下你可以获得的多少种不同的幸运的袋子。 

解法:先排序 然后dfs+剪枝

要满足a+b>a*b的话  a和b里面肯定会有1 

#include<iostream>
#include<algorithm>
using namespace std;
const int N=1e3+10;
int x[N];
int n;
int ans;
void dfs(int pos,int sum,int ji)
{	for(int i=pos;i<=n;i++){sum+=x[i];ji*=x[i];if(sum>ji){ans++;dfs(i+1,sum,ji);}else if(x[i]==1) dfs(i+1,sum,ji);else break;sum-=x[i];ji/=x[i];//去重while(i<=n&&x[i]==x[i+1])i++;}
}
int main()
{cin>>n;for(int i=1;i<=n;i++)cin>>x[i];sort(x+1,x+n+1);dfs(1,0,1);cout<<ans<<endl;return 0;
}

 T2:计算日期到天数转换

链接:计算日期到天数转换_牛客题霸_牛客网 (nowcoder.com)

 

emmm 偷个懒 模拟题

主要考察数组的应用和平闰年判断 

T3:手套

链接:手套__牛客网 (nowcoder.com) 

题目描述:

在地下室里放着n种颜色的手套,手套分左右手,但是每种颜色的左右手手套个数不一定相同。A先生现在要出门,所以他要去地下室选手套。但是昏暗的灯光让他无法分辨手套的颜色,只能分辨出左右手。所以他会多拿一些手套,然后选出一双颜色相同的左右手手套。现在的问题是,他至少要拿多少只手套(左手加右手),才能保证一定能选出一双颜色相同的手套。

给定颜色种数n(1≤n≤13),同时给定两个长度为n的数组left,right,分别代表每种颜色左右手手套的数量。数据保证左右的手套总数均不超过26,且一定存在至少一种合法方案。

 题目瞪了半天:你需要从这俩个数组中挑出一些手套,保证从中一定有一双颜色相同的手套。要求挑出的数量最小。

class Gloves{
public:int findMinimum(int n,vector<int> left,vector<int> right){int sum=0;int l_mi=1e9,r_mi=1e9,l_sum=0,r_sum=0;for(int i=0;i<n;i++){if(left[i]*right[i]==0){sum+=left[i]+right[i];}else{l_sum+=left[i];l_mi=min(l_mi,left[i]);r_sum+=right[i];r_mi=min(r_mi,right[i]);}}int mi=min(l_sum-l_mi+1,r_sum-r_mi+1)+1;return sum+mi;}
};

 T4:二进制中1的个数

链接:二进制中1的个数_牛客题霸_牛客网 (nowcoder.com)

 

法1:位运算,n&(n-1)相当于每次把最右边的1变成0

class Solution {
public:int NumberOf1(int n) {int cnt=0;while(n){n&=(n-1);cnt++;}return cnt;}
};

法2:bitset的应用,bitset中存放是二进制,bitset.count()求的是1的个数 

class Solution {
public:int NumberOf1(int n) {bitset<32>f(n);return f.count();}
};

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/126911.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM(八股文)

目录 一、JVM简介 二、JVM中的内存区域划分 三、JVM加载 1.类加载 1.1 加载 1.2 验证 1.3 准备 1.4 解析 1.5 初始 1.6 总结 2.双亲委派模型 四、JVM 垃圾回收&#xff08;GC&#xff09; 1.确认垃圾 1.1 引用计数 1.2 可达性分析&#xff08;Java 采用的方案&a…

让照片人物开口说话,SadTalker 安装及使用(避坑指南)

AI技术突飞猛进&#xff0c;不断的改变着人们的工作和生活。数字人直播作为新兴形式&#xff0c;必将成为未来趋势&#xff0c;具有巨大的、广阔的、惊人的市场前景。它将不断融合创新技术和跨界合作&#xff0c;提供更具个性化和多样化的互动体验&#xff0c;成为未来的一种趋…

华为OD机试 - 计算最大乘积(2022Q4 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷&#…

javaWeb网上购物系统的设计与实现

摘 要 随着计算机网络技术的飞速发展和人们生活节奏的不断加快&#xff0c;电子商务技术已经逐渐融入了人们的日常生活当中&#xff0c;网上商城作为电子商务最普遍的一种形式&#xff0c;已被大众逐渐接受。因此开发一个网上商城系统&#xff0c;适合当今形势&#xff0c;更加…

自动化项目实战->测试博客系统

1.熟悉项目-->哪些场景容易出现问题 2.针对核心流程设计测试用例(手工测试用例) 3.将手工测试用例转换为自动化测试用例 4.部署到服务器 一、针对核心流程设计测试用例 二、将手工测试用例转换为自动化测试用例 2.1设计自动化测试用例的代码结构 初始化动作:BeforeAll--…

一篇理解TCP协议

一、TCP协议概念。 TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是一种面向连接的、可靠的传输层协议。它主要用于在计算机网络中&#xff0c;通过建立可靠的通信连接来进行数据传输。 TCP协议的特点如下&#xff1a; 可靠性&#xf…

九、互联网技术——记忆背诵

文章目录 一、网络操作系统的功能和特性二、网络操作系统的逻辑构成四、主动攻击和被动攻击五、安全机制和安全服务六、信息与数据七、数据处理与数据管理八、数据模型九、概念模型的E-R表示方法十、四种数据模型十一、数据库系统组成十二、DBMS主要功能十三、数据库系统的3级模…

最新AI创作系统源码ChatGPT网站源码V2.6.3/支持Midjourney绘画/支持OpenAI GPT全模型+国内AI全模型

一、AI创作系统 SparkAi创作系统是基于OpenAI很火的ChatGPT进行开发的Ai智能问答系统&#xff0c;支持OpenAI GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美&#xff0c;可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作Chat…

【C语言初阶】分支语句和循环语句

目录 一、什么是语句 二、分支语句 2.1 if 语句 2.1.1 悬空else 2.1.2 if 书写形式的对比 2.2 switch语句 2.2.1 在switch语句中的 break 2.2.2 default子句 2.2.3 练习 三、循环语句 3.1 while循环 3.1.1 while语句中的break 3.1.2 while语句中的continue 3.2 fo…

[JAVAee]SpringBoot-AOP

目录 Spring AOP ​编辑AOP适用场景 AOP的组成 连接点(Join Point) 切点(Pointcut) 通知(Advice) Spring AOP的实现 添加依赖 定义切面与切点 切点表达式的说明 定义相关的通知 Spring AOP AOP(Aspect Oriented Programming)是面向切面编程,是一种设计思想.对某一类…

MySQL实战基础知识入门(13):数据类型

MySQL实战基础知识入门 MySQL实战基础知识入门(1)&#xff1a;登录数据库命令行MySQL实战基础知识入门(2)&#xff1a;统计一天24小时数据默认补0的sql语句MySQL实战基础知识入门(3)&#xff1a;近7日销量合计php后端mysql语句如果当日为空则自动补0的解决方案MySQL实战基础知…

Qt扫盲-QTreeView 理论总结

QTreeView 理论使用总结 一、概述二、快捷键绑定三、提高性能四、简单实例1. 设计与概念2. TreeItem类定义3. TreeItem类的实现4. TreeModel类定义5. TreeModel类实现6. 在模型中设置数据 一、概述 QTreeView实现了 model 中item的树形表示。这个类用于提供标准的层次列表&…