蓝桥--矩阵翻硬币--二分枚举

问题描述

小明先把硬币摆成了一个 n 行 m列的矩阵。随后,小明对每一个硬币分别进行一次 Q操作。

对第x行第y列的硬币进行Q操作的定义:将所有第 ix行,第 jy列的硬币进行翻转。其中i和j为任意使操作可行的正整数,行号和列号都是从1开始。

当小明对所有硬币都进行了一次 Q 操作后,他发现了一个奇迹——所有硬币均为正面朝上。

小明想知道最开始有多少枚硬币是反面朝上的。于是,他向他的好朋友小M寻求帮助。

聪明的小M告诉小明,只需要对所有硬币再进行一次Q操作,即可恢复到最开始的状态。然而小明很懒,不愿意照做。于是小明希望你给出他更好的方法。帮他计算出答案。

【数据格式】

输入数据包含一行,两个正整数 n m,含义见题目描述。输出一个正整数,表示最开始有多少枚硬币是反面朝上的。

【样例输入】

2 3

【样例输出】

1

【数据规模】

对于10%的数据,n、m <= 10^3;

对于20%的数据,n、m <= 10^7;

对于40%的数据,n、m <= 10^15;

对于10%的数据,n、m <= 10^1000(10的1000次方)。

==真因子==是指能整除一个给定数但不等于该数本身的因子,只有平方数的真因子个数为奇数

说人话

  • Q操作:将x的倍数行和y的倍数行反转
  • 一开始反面朝上的硬币数量一定是经历了奇数次反转的那些硬币,即 硬币只有被翻动奇数次才会有效果
  • 对于(10,5)处的硬币:行的真因子:(1,10,2,5),列的真因子(1,5),所以一共会被翻4*2次
  • 翻奇数次的前提是:行列真因子之积为奇数,即他们全是平方数,问题转化为寻找矩阵中下标均为平方数的元素个数

Try1n以内平方数的个数

def f(n): #运行超时
#   # 返回n以内平方数的个数
#   cnt = 0
#   for i in range(1,n+1):
#     if(n**0.5).is_integer():
#       # 平方数开根号一定为整数
#       cnt+=1
#   return cnt
def f1(n):#通过10%
#   cnt1 =0
#   for i in range(1,n+1):
#     if math.sqrt(i).is_integer():
#       cnt1 += 1
#   return cnt1  
# print(f1(n)*f1(m))

try2由于遍历的数目太大导致超时,所以优化算法,用二分枚举
枚举n以内平方小于n的个数,非平方的因子数是成对出现的,只出现在前半部分,所以mid =(l+r)//2+1(+1是向上取整,防止错过平方数),最终的l代表有几组因子(翻动了几次),由于最终态为全部正面朝上,所以初态正面朝下的个数就是?????

def number(x): #二分枚举 找平方不大于x的个数。100%通过left=1    #因为真因子1,a1 b1,a2 b2,。。。k(k为开方数),# 所以平方不大于x就表示a1,a2。。这些因子right=xwhile left<right:mid=(left+right)//2+1 #向上取整 加1是表示看看后一位是否为平方数if mid**2>x:right=mid-1else:left=midreturn left
print(number(n)*number(m))
import os
import sys
import math
# Q操作:将x的倍数行和y的倍数行反转
# 对于(105)处的硬币:
# 行的真因子:(11025),列的真因子(15),所以一共会被翻4*2次
# 真因子是指能整除一个给定数但不等于该数本身的因子,只有平方数的真因子个数为奇数
# 硬币只有被翻动奇数次才会有效果
# 翻奇数次的前提是:行列真因子之积为奇数,即他们全是平方数
# 问题转化为寻找矩阵中下标均为平方数的元素个数
n,m = map(int,input().split())# def f(n): #运行超时
#   # 返回n以内平方数的个数
#   cnt = 0
#   for i in range(1,n+1):
#     if(n**0.5).is_integer():
#       # 平方数开根号一定为整数
#       cnt+=1
#   return cnt
# def f1(n):#通过10%
#   cnt1 =0
#   for i in range(1,n+1):
#     if math.sqrt(i).is_integer():
#       cnt1 += 1
#   return cnt1  
# print(f1(n)*f1(m))def number(x): #二分枚举 找平方不大于x的个数。100%通过left=1    #因为真因子1,a1 b1,a2 b2,。。。k(k为开方数),# 所以平方不大于x就表示a1,a2。。这些因子right=xwhile left<right:mid=(left+right)//2+1 #向上取整 加1是表示看看后一位是否为平方数if mid**2>x:right=mid-1else:left=midreturn left
print(number(n)*number(m))

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

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

相关文章

python脚本过滤得到non-overlap的utr

使用该脚本对上述的结果"lin_20240321_calculating_rG4score.R"进行过滤 import csvdef read_file(file_path):with open(file_path, r) as file:reader csv.DictReader(file, delimiter\t)return list(reader)def process_sequences(data):gene_sequences {}for …

跨域以及跨域配置

1、什么跨域 首先&#xff0c;在前后端没有分离项目&#xff0c;例如jsp、php&#xff0c;前后台代码没有实现物理上的分离。不存在跨域问题。前后端分离后&#xff0c;前后端的地址域名不同&#xff0c;而同源策略导致浏览器会拦截a地址访问b地址请求&#xff08;a地址通过浏览…

云虚拟主机有哪些作用?

云虚拟主机是一款虚拟主机产品&#xff0c;云虚拟主机是由云计算与虚拟主机共同产生的&#xff0c;接下来小编就带领大家一起来了解一下云虚拟主机都有哪些作用吧&#xff01; 云虚拟主机能够通过在多个服务器上分散虚拟机实例&#xff0c;来提高服务器的可用性和冗余备份&…

39.组合总和40组合总和2

39.组合总和 思路 还是按照组合回溯的思想来解&#xff0c;与原先组合区别就是集合内的元素可重复使用&#xff0c;刚开始考虑原先回溯中startIndex是为了避免重复&#xff0c;那么只需每层递归for循环都完全遍历集合中的元素即可。 但结果出现了排列不同的结果&#xff0c;…

【前端】Web Audio API接口介绍

简言 记录下Web Audio API接口的介绍。 Web Audio API 提供了在 Web 上控制音频的一个非常有效通用的系统&#xff0c;允许开发者来自选音频源&#xff0c;对音频添加特效&#xff0c;使音频可视化&#xff0c;添加空间效果&#xff08;如平移&#xff09;&#xff0c;等等。 …

tomcat安装及配置教程

在安装和配置Tomcat之前&#xff0c;请确保已经安装了Java Development Kit (JDK)。以下是安装和配置Tomcat的步骤&#xff1a; 下载Tomcat。访问Tomcat官方网站&#xff0c;选择适合您需求的版本&#xff08;例如Tomcat 8或9&#xff09;&#xff0c;下载并解压到您的计…

Obsidian插件PicGo-图床创建使用[腾讯云保姆级教程]

一、下载PicGo并配置 1&#xff1a;安装插件 首先插件市场搜索picgo会出现Image auto upload&#xff0c;这个就是PicGo安装此插件并启用即可 2&#xff1a;安装PicGo软件 打开此链接&#xff1a;https://github.com/Molunerfinn/PicGo 自己选择一个方式下载&#xff0c;我…

javascript高级-数组的方法

javascript高级-数组的使用方法 改变原数组返回一个新数组或不改变原数组的等应用场景,如下这些方法在实际项目中通常会用上 getArrlen() {//1.改变原数组的方法let arr [1, 2, 3];arr.push(6); //给数组最后面的添加元素console.log(push, arr); //[1,2,3,6]arr.pop(); //删…

数字乡村发展策略:科技引领农村实现跨越式发展

随着信息技术的迅猛发展和数字经济的崛起&#xff0c;数字乡村发展策略已经成为引领农村实现跨越式发展的重要手段。科技的力量正在深刻改变着传统农业的生产方式、农村的社会结构以及农民的生活方式&#xff0c;为农村经济发展注入了新的活力和动力。本文将从数字乡村的内涵、…

第十四届蓝桥杯JavaB组省赛真题 - 幸运数字

进制转换可以参考如下的十进制&#xff0c;基本一样的&#xff0c;只是把10变成了其他数字&#xff0c; sum就是各个数位之和 public static int myUtil(int n) {int sum 0;while(n > 0) {sum n % 10;n / 10;}return sum;} 注意&#xff1a; 如果写在同一个类里面&…

苍穹外卖-day15:套餐管理

套餐管理 课程内容 套餐分页查询启售停售套餐删除套餐新增套餐 1. 套餐分页查询 1.1 需求分析和接口设计 根据产品原型来了解需求&#xff0c;套餐分页查询的产品原型如下&#xff1a; 业务规则&#xff1a; 根据页码展示套餐信息(套餐名称、套餐图片、套餐分类、价格、售…

4.1.1 SN74HC05N型反相器(OD门)

1、OD门介绍 为提高逻辑门驱动负载的能力,输出端漏极开路的OD门被广泛使用。使用时,OD门需外接一只电阻上拉到电源正极。相同型号的OD门可以进行多只并联,实现“线与”的逻辑功能。 常用的OD门芯片有74HC05N、I2C设备等。 2、SN74HC05N型反相器(OD门) 2.1 引脚分布和功…

mosquitto - 笔记

1 mosquitto心跳和网络重连机制&#xff08;基于MQTT协议&#xff09;mosquitto心跳和网络重连机制&#xff08;基于MQTT协议&#xff09;_mqtt重连机制-CSDN博客 2. mosquitto简单应用 https://www.cnblogs.com/embedded-linux/p/9386169.html

Java中的并发并行与生命周期

并发并行与生命周期 并发、并行什么是进程并发的含义并行的理解多线程是如何在执行 线程的生命周期Java线程的状态线程的6中状态互相转换 并发、并行 什么是进程 正在运行的程序&#xff08;软件&#xff09;就是一个独立的进程线程是属于进程的&#xff0c;一个进程中可以同…

全网最全的Postman接口自动化测试(史实级攻略)

软件测试面试刷题&#xff0c;这个小程序&#xff08;永久刷题&#xff09;&#xff0c;靠它快速找到工作了&#xff01;&#xff08;刷题APP的天花板&#xff09;【持续更新最新版】-CSDN博客 背景 该篇文章针对已经掌握 Postman 基本用法的读者&#xff0c;即对接口相关概念…

2024年Jira全面解析:从 Jira 的概念到优缺点、最新政策

Jira是澳大利亚的Atlassian公司开发的一款项目管理软件&#xff0c;名字来源于日文中“哥斯拉”的称呼“Gojira”。Jira不仅可以追踪缺陷和问题&#xff0c;还能管理项目。很多企业还将JIRA用于一些特殊的场景&#xff0c;比如作为仓库自动化工具、管理文档流程、优化费用等等。…

四川易点慧电子商务抖音小店:安全可靠,购物新选择

在数字化浪潮席卷全球的今天&#xff0c;电子商务已成为人们生活中不可或缺的一部分。四川易点慧电子商务抖音小店作为新兴的电商平台&#xff0c;以其安全可靠、便捷高效的特点&#xff0c;逐渐赢得了广大消费者的青睐。今天&#xff0c;就让我们一起走进四川易点慧电子商务抖…

Python Windows系统 虚拟环境使用

目录 1、安装 2、激活 3、停止 1、安装 1&#xff09;为项目新建一个目录&#xff08;比如&#xff1a;目录命名为learning_log&#xff09; 2&#xff09;在终端中切换到这个目录 3&#xff09;执行命令&#xff1a;python -m venv ll_env&#xff0c;即可创建一个名为ll…

抖音开放平台的订单类API接口调用测试指南(内含详细步骤)

一、什么是抖音开放平台 抖音开放平台基于抖音母体&#xff0c;提供抖音服务基础设施和创新行业解决方案的平台。同时满足各类各类机构、创作者及服务商对于内容获取、分享的个性化需求&#xff0c;我们诚邀各个行业、不同阶段的合作伙伴与我们一起&#xff0c;共建内容良性生…

【数据结构】布隆过滤器

SueWakeup 个人主页&#xff1a;SueWakeup 系列专栏&#xff1a;学习技术栈 个性签名&#xff1a;保留赤子之心也许是种幸运吧 本文封面由 凯楠&#x1f4f8; 友情提供 目录 本栏传送门 前言 1. 什么是布隆过滤器&#xff1f; 2. 布隆过滤器的原理 2.2 判断元素存在原理…