24.4.20 蚂蚁笔试(开发)a1.09

只是个人记录,玻璃心请大佬轻喷,如果有幸能得到大佬的指教那就更好啦~

若干单选和多选,感觉没有太难。下面是三个算法题(记不住具体的题目了,)

题目1

大致题意:数组a有n个元素,让求数组a的权值(权值计算方式:正数元素个数-负数元素个数)。现在对其中k个元素取反(取其相反数),求现在数组a的权值最大为多少?

输入描述:

第一行 n代表数组元素个数,k代表修改的元素个数

第二行 数组a,元素以空格隔开

题解:一定不要忘记0    让k先对负数取反,可能的话,剩下的取反施加再0上面,最后不得已再施加在正数上面。

伪码:

x=正数个数

y=负数个数

z=0的个数

if k <y:

        print(x+k-y)

elif k==y:

        print(x+k)

else:

        if k<=z+y:

                print(x+y)

        else:

                print(x+y-(k-y-z)-(k-y-z))

题目2

大致题意:构造数字x=x*k,x初始为1,k是由1或2组成的数字(满足条件的k如2,12,121,22221等),求x最少成几次能够变成n.  输入描述:一个数字n(n最大为2*1e5)代表x终点,输出描述:y代表最少次数

输入描述:

第一行 n代表构造目标

输出描述:

第一行 代表最少次数

题解: 随便输出的,过了4%. 不太会

事后和同学讨论,也许可以先打表,因为n最大并不是很大。然后dfs.

result =[]
ans = 18
def find_numbers():numbers = []for i in range(1, 200001):if all(digit in ['1', '2'] for digit in str(i)):numbers.append(i)return numbers
def check(n,res,cur):global result,ansif cur==len(result):returnif n==1:ans = min(ans,res)returnfor i in range(len(result)):if n%result[i]==0:check(n/result[i],res+1,i+1)result = find_numbers()
result.sort(reverse=True)
#print(result)
myset = (1,2,4,6,8)
t = int(input())
for i in range(t):n = int(input())if n%10 not in myset:print(-1)continueif n==1:print(0)continueans = 18  ##log2*1e5<18check(n,0,0)if ans == 18:ans = -1print(ans)

题目3

大致题意:数组a每个元素代表硬币金额,数组p代表取出第i个硬币的概率(具体概率这样计算p[i]/sum(p数组)),现在求取出硬币的和不小于x的期望。
输入:
第一行n,x分别代表数组元素个数和目标
第二行 就是数组a
第三行 是数组p

(数组a元素大小最大为500,n,x最大也是500)
输出:
期望模mod=1e9+7(期望可以由有理数x/y表示,要求输出(x/y%mod))它提示:对分数取模可以这样算,在[1,p-1]区间内找一个k,满足k*y%mod==x,这个k就是要的结果。

样例,
输入
2 5
3 6
2 4
样例解释:3取2次才不小于5,概率是1/3,6取一次满足不小于5,概率为2/3.期望就是2/3 *2  +   2/3*1=4/3,最后输出4/3模mod,结果为:333333337.

题解:用python的pow函数过了5%,但是感觉没什么问题不知道为啥了。事后讨论:前面计算期望简单,分数取模那里,使用扩展欧几里得求逆元的思想:参考以下

def modinv(x, mod):# 扩展的欧几里德算法求解模数逆元def egcd(a, b):if a == 0:return (b, 0, 1)else:g, y, x = egcd(b % a, a)return (g, x - (b // a) * y, y)gcd, x_inv, _ = egcd(x, mod)if gcd != 1:raise Exception('Modular inverse does not exist')else:return x_inv % mod
###k*y%mod ==x 利用逆元(x*x'%mod=1,则x'即为x%mod的逆元)的思想,把右边化为1
###k*y*x'%mod ==1   x’是x%mod的逆元
###k*(y*x')%mod ==1 最后也就是求(y+x')%mod的逆元
x = 4
mod = pow(10,9)+7
x_inv = modinv(x, mod)
y = 3
x = x_inv*y
x_inv = modinv(x,mod)
print("逆元是:", x_inv)

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

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

相关文章

Windos环境下配置免费SSL证书详细步骤

获取免费证书 配置本机模拟域名 打开如下目录&#xff0c;hosts文件 C:\Windows\System32\drivers\etc 添加如下配置并保存 127.0.0.1 im.test.com下载安装 OpenSSL 下载链接 进入bin目录&#xff0c; 打开cmd窗口 执行如下命令&#xff0c;生成RSA私钥 ## 使用des3…

大型集团企业 怎么实现多区域文件交换?

很多大型集团企业&#xff0c;都会在全国各地&#xff0c;甚至海外&#xff0c;都设立分支机构&#xff0c;还有银行、邮政这类机构&#xff0c;都会在全国各地设立多个支行和网点&#xff0c;所以在日常经营过程中&#xff0c;都会存在多区域文件交换的场景。 大型集团企业在进…

JVM垃圾收集器--分区收集器

G1收集器 G1&#xff08;Garbage-First Garbage Collector&#xff09;在 JDK 1.7 时引入&#xff0c;在 JDK 9 时取代 CMS 成为了默认的垃圾收集器。G1 有五个属性&#xff1a;分代、增量、并行、标记整理、STW。 分代 G1收集器 将内部分为多个大小相等的区域&#xff0c;另…

Unity Shader 图形学【笔记一】

游戏图形学 源自&#xff1a;计算机图形学 涵盖&#xff1a;图形、动画的创建渲染展示 目标&#xff1a;性能优化、提高视觉质量&#xff0c;增强用户体验 技术&#xff1a;三维模型、纹理、光照、阴影、特效、动画、物理模拟、碰撞检测等 Unity Shader 是&#xff1a;un…

基于Vue+ElementPlus自定义带历史记录的搜索框组件

前言 基于Vue2.5ElementPlus实现的一个自定义带历史记录的搜索框组件 效果如图&#xff1a; 基本样式&#xff1a; 获取焦点后&#xff1a; 这里的历史记录默认最大存储10条&#xff0c;同时右侧的清空按钮可以清空所有历史记录。 同时搜索记录也支持点击搜索&#xff0c;按…

c++ reinterpret_cast类型转换简单实验

1.概要 c提供如下几种转换&#xff0c;具体如下。 static_cast&#xff1a;用于非多态类型的转换。 dynamic_cast:用于多态类型的转换&#xff0c;主要用于向下类型转换&#xff08;从基类指向派生类的指针/引用&#xff09;&#xff0c;会检查转换的有效性&#xff0c;如果转…

371D - Vessels

思路&#xff1a;用并查集维护&#xff0c;如果当前容器没有满&#xff0c;就指向自己&#xff0c;否则指向下一个容器。 这样就可以快速 find 到下一个没有满的容器&#xff0c;从而模拟询问 1。 代码&#xff1a; void solve(){int n;cin >> n;vector<int>p(n …

leetcode:滑动窗口----3. 无重复字符的最长子串

给定一个字符串 s &#xff0c;请你找出其中不含有重复字符的 最长 子串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc"&#xff0c;所以其长度为 3。示例 2: 输入: s "bbbbb" 输出: 1 解释: 因为…

算法竞赛相关问题总结记录

前言 日常在校生或者是工作之余的同学或多或少都会参加一些竞赛,参加竞赛一方面可以锻炼自己的理解与实践能力&#xff0c;也能够增加自己的生活费&#xff0c;竞赛中的一些方案也可以后续作为自己论文的base,甚至是横向课题的框架。在算法竞赛中算法的差别个人感觉差距都不大&…

CUDA流与异步

CUDA流与异步 基于流的异步的内核启动和数据传输支持以下类型的粗粒度并发&#xff1a; 1.重叠主机计算和设备计算&#xff1b; 2.重叠主机计算和主机与设备间的数据传输&#xff1b; 3.重叠主机与设备间的数据传输和设备计算&#xff1b; 4.并发设备计算。 理解一个CUDA程序&…

安卓手机APP开发__媒体开发部分__播放器的接口

安卓手机APP开发__媒体开发部分__播放器的接口 目录 概述 组件之间的共同的接口 媒体3的播放的架构 播放器的状态 对改变的监听 当前的播放 定制的播放器实现 概述 一个播放器是你的APP中完成媒体项的播放的组件. 媒体3的播放器接口提供了一个关于播放器处理的功能的总…

一招搞定“找不到xinput1_3.dll,无法继续执行代码”问题

在我们日常使用电脑进行各类工作的过程中&#xff0c;特别是在运行一些关键性软件以完成特定任务时&#xff0c;电脑屏幕上突然弹出一条醒目的错误提示信息&#xff1a;“由于找不到xinput1_3.dll,无法继续执行代码”。这个错误通常发生在使用DirectInput库时&#xff0c;而xin…

Java Spring框架的核心优势是什么?

Spring框架是Java企业应用开发中广泛使用的开源框架&#xff0c;它旨在简化企业级应用的开发。Spring框架的核心优势主要体现在以下几个方面&#xff1a; 轻量级和松耦合&#xff1a;Spring框架设计得非常轻量级&#xff0c;它的大小和复杂性都相对较低&#xff0c;这使得开发者…

BFS解决FloodFill算法:(Leetcode:733. 图像渲染)

题目链接&#xff1a;733. 图像渲染 - 力扣&#xff08;LeetCode&#xff09; 使用广度优先遍历算法解决该问题&#xff1a; 从初始位置开始搜索&#xff0c;初始位置符合条件就入栈&#xff0c;并修改初始位置值。初始位置出栈。 再从初始位置开始广度优先搜索&#xff08;…

代码随想录算法训练营第三十四天|1005.K次取反后最大化的数组和,134. 加油站,135. 分发糖果

目录 1005.K次取反后最大化的数组和思路代码 134. 加油站思路代码 135. 分发糖果思路代码 1005.K次取反后最大化的数组和 题目链接&#xff1a;1005.K次取反后最大化的数组和 文档讲解&#xff1a;代码随想录 视频讲解&#xff1a;贪心算法&#xff0c;这不就是常识&#xff1f…

阿赵UE学习笔记——30、HUD简单介绍

阿赵UE学习笔记目录 大家好&#xff0c;我是阿赵。   继续学习虚幻引擎&#xff0c;这次来学习一下HUD的基础使用。 一、 什么是HUD HUD(Head-Up Display)&#xff0c;也就是俗称的抬头显示。很多其他领域里面有用到这个术语&#xff0c;比如开车的朋友可能会接触过&#xf…

【Camera Sensor Driver笔记】一、Sensor基本概念

时钟 sensor clock sensor的输入时钟 MCLK 输出时钟&#xff1a; 1. VTPixelClock&#xff1a;会影响sensor内部的帧率、曝光 VTPixelClock(vt_clk)Video Timing Clock, From sensor PLL VTPixelClock Framelengthlines x LinelengthPixelClock x FPS Framelengthlines L…

页面加载事件

2.1窗口加载事件 1.window.οnlοadfuction(){} 或者 window.addEventListerner(‘load’,function(){}) doucument.addEventListner(DOMContentLoaded,fuction(){})这个反应更快些

是德软件89600 RFID使用笔记

文章目录 1、进入RFID软件&#xff1a;2、RFID软件解调设置项3、如何查看一段指令数据 本文是日常工作的笔记分享。 lauch VSA&#xff08;矢量频谱分析&#xff09;后会出现以下界面&#xff1a; 当然这是因为频谱仪的输入有信号才显示如下&#xff1a; 否则就显示频谱仪的噪…

初识C++ · 类和对象(中)(2)

前言&#xff1a;上篇文章已经介绍了6个默认成员函数中的3个函数&#xff0c;分别是构造函数&#xff0c;析构函数&#xff0c;拷贝构造函数&#xff0c;本文介绍的是后三个&#xff0c;赋值运算符重载&#xff0c;const成员函数&#xff0c;取地址操纵符重载。 目录​​​​​…