蓝桥杯:C++模运算、快速幂

模运算

模运算是大数运算中的常用操作。如果一个数太大,无法直接输出,或者不需要直接输出,则可以对它取模,缩小数值再输出。取模可以防止溢出,这是常见的操作。

模是英文mod的音译,取模实际上是求余。

取模运算一般要求a和m的符号一致,即都为正数或都为负数。如果正负不同,那么请小心处理。

取模操作的加、减、乘满足分配律,注意此时仍要求a+b、a−b、a×b为正数,如果有负数,请小心处理。

例题1.刷题统计

2022年(第十三届)省赛,lanqiaoOJ题号2098

这题用暴力法很好解,但是只能拿到60的测试数据,差不多对一半吧。

暴力法代码:

#include <iostream>
using namespace std;
int main()
{
  // 请在此输入您的代码
  long long a,b,n;  //要用long long 
  cin >> a >> b >> n;
  long long sum = 0,day = 0;  //定义做题数和天数
  while(sum < n){
    day++;
    if(day % 7 == 6 || day % 7 == 0) sum+=b;//周六周日
    else sum+=a;//周一到周五

  }
  cout << day;
  return 0;   //暴力法通过60,后面运行超时,这个是意料之中的。
}

放在取模题中,这也是一道取模的简单题,利用取模操作把计算复杂度降为O(1)。

代码:

#include<bits/stdc++.h>
using namespace std;
int main()
{
    long long a,b,n;
    cin >> a >> b >> n;
    long long sum=5*a+2*b;//一周总数
    long long day=7*(n/sum);//总数除以一周总数乘以一周7天
    n=n%sum;//剩余题目
    long long d[]={a,a,a,a,a,b,b},i;//设立周数组
    for(i=0;n>0;i++)  
    {
        //当n=0时,就已经满足大于等于n,这个时候的天数就是答案
        n-=d[i];
        day++;
    }
    cout << day; 
    return 0;
}

快速幂

int fastPow(int a, int n) {    //快速幂 
	int ans = 1;               //用ans返回结果,初始化为1,不能初始化为0
	while(n) {                 //把n看成二进制数,逐个处理它的最后一位
		if(n & 1)   ans *= a;  //如果n的最后一位是1,则表示这个地方需要参与计算
		a *= a;                //递推:a2 --> a4 --> a8--> a16-->…
		n >>= 1;               //n右移一位,把刚处理过的n的最后一位去掉
	}
	return ans;                //结果
}

例题1.快速幂

套模板即可,代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;                      //变量改用较大的long long型
ll fastPow(ll a, ll n, ll mod) {
	ll ans = 1;
	a %= mod;                             //非常重要,防止下面的ans*a越界
	while(n) {
		if(n & 1)   ans = (ans*a) % mod;   //取模
		a = a*a % mod;                     //取模
		n >>= 1;
	}
	return ans;       					   //输出结果 
}
int main() {
	ll b,p,k;
	cin>>b>>p>>k;
	cout << fastPow(b,p,k);
	return 0;
}

矩阵乘法

矩阵的加减法很简单,把两个矩阵对应位置的元素进行加减即可得到结果。

矩阵乘法:

for(int i=1; i<=m; i++)     //注:i、j、k的先后顺序不重要,因为对于c[][]来说都一样
	for(int j=1; j<=u; j++)
		for(int k=1; k<=n; k++)
			c[i][j] += a[i][k] * b[k][j]);

根据矩阵乘法的定义,可以推出下面两个式子。

例题1.矩阵相乘

代码:

#include<bits/stdc++.h>
using namespace std;
const int N=100;
int n,m,k;
int A[N][N],B[N][N],C[N][N];
int multi(int  u, int v) {
	int sum = 0;
	for (int j=0; j<m; j++)  sum += (A[u][j] * B[j][v]);
	return sum;
}
int main() {
	cin >> n >> m >> k;
	for(int i=0; i<n; i++)
		for(int j=0; j<m; j++)    cin >> A[i][j];
	for(int i=0; i<m; i++)
		for(int j=0; j<k; j++)    cin >> B[i][j];
	for(int i=0; i<n; i++)
		for(int j=0; j<k; j++)    C[i][j] = multi(i, j);
	for(int i=0; i<n; i++) {
		for(int j=0; j<k; j++)    cout << C[i][j] << " ";
		cout << endl;
	}
	return 0;
}

GCD和LCM

最大公约数(Greatest Common Divisor,GCD)和最小公倍数(the Least Common Multiple,LCM)。

编程时可以不用自己写GCD代码,而是直接使用库函数。

C++的库函数__gcd()。

__gcd();   //shift  + -,输出_     注意是两个下划线,所以要操作两次shift+-

库函数__gcd()可能会返回负数,见下面的例子。

#include<bits/stdc++.h>
using namespace std;
int main() {
	cout<<__gcd(15, 81)<< endl;    //输出  3
	cout<<__gcd(0, 44)<< endl;     //输出  44
	cout<<__gcd(0, 0)<< endl;      //输出  0
	cout<<__gcd(-6, -15)<< endl;   //输出  -3
	cout<<__gcd(-17,289)<< endl;   //输出  -17
	cout<<__gcd(17,-289)<< endl;   //输出  17
	return 0;
}

LCM:

gcd(a, b)×lcm(a, b) = a×b,即lcm(a, b) = a×b/gcd(a, b) =a/gcd(a, b) ×b。

例题1.等差数列

解析:

代码: 

#include<bits/stdc++.h>
using namespace std;
int a[100000];
int main() {
	int n;
	cin>>n;
	for(int i=0; i<n; i++)   cin>>a[i];
	sort(a,a+n);
	int d=0;
	for(int i=1; i<n; i++)   d = __gcd(d,a[i]-a[i-1]);    //以{2,5,7}为例
	if(d==0) cout<<n<<endl;    //公差为0,直接输出n就行
	else     printf("%d\n",(a[n - 1] - a[0]) / d + 1); 
	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

晨曦记账本,微信账单全解析,轻松掌握收支明细与总花销!

在这个数字化时代&#xff0c;微信已不仅仅是一个简单的社交工具&#xff0c;更是我们日常生活中不可或缺的支付与收款平台。从购买早餐、支付水电费到线上购物&#xff0c;微信支付已经渗透到我们生活的方方面面。然而&#xff0c;你是否曾经对自己的微信消费产生过疑惑&#…

模型 4i(趣味、利益、互动、个性)理论

系列文章 分享 模型&#xff0c;了解更多&#x1f449; 模型_总纲目录。重在提升认知。以用户为中心营销。 1 模型 4i(趣味、利益、互动、个性)理论的应用 1.1 4i理论在电子商务中的应用 小米公司在其电子商务平台上运用了 4i理论&#xff0c;取得了较好的效果。具体表现如下…

亚马逊速卖通temu:店铺产品怎么才能上首页爆单并且不翻车

在亚马逊平台上经营的卖家&#xff0c;深知平台规则的重要性。每个产品的销量和评价&#xff0c;特别是关键词的排名&#xff0c;对产品的推广至关重要。如果一个产品在亚马逊上没有评论和销量&#xff0c;其推广成本会大大增加。无论是通过官方渠道还是其他途径&#xff0c;卖…

C语言第二十六弹---字符串函数(下)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 目录 1、strncat 函数的使用 2、strncmp 函数的使用 3、strstr 函数的使用和模拟实现 4、strtok 函数的使用 5、strerror 函数的使用 6、perror 函数的使用…

1.初识Tauri

文章目录 一、前言二、基本认识三、js与rust通信四、构建应用 一、前言 原文以及后续文章可点击查看&#xff1a;初识Tauri。 Tauri是一款比较新的跨平台桌面框架&#xff0c;也是我目前最喜欢的一个框架&#xff0c;其官网为&#xff1a;Tauri 它的作用其实和Electron很像&…

js---webAPI

01 声明变量 js组成&#xff1a; DOM:操作网页内容的,开发页面内容特效和实现用户交互 BOM: DOM树&#xff1a;将 HTML 文档以树状结构直观的表现出来&#xff0c;我们称之为文档树或 DOM 树 文档树直观的体现了标签与标签之间的关系 CSS获取元素的方法 document.querySele…

代码随想录算法训练营第三十四天|860.柠檬水找零 406.根据身高重建队列 452. 用最少数量的箭引爆气球

860.柠檬水找零 链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 细节&#xff1a; 1. 首先根据题意就是只有5.的成本&#xff0c;然后就开始找钱&#xff0c;找钱也是10.和5. 2. 直接根据10 和 5 进行变量定义&#xff0c;然后去循环…

每日OJ题_算法_递归④力扣24. 两两交换链表中的节点

目录 ④力扣24. 两两交换链表中的节点 解析代码 ④力扣24. 两两交换链表中的节点 24. 两两交换链表中的节点 难度 中等 给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题&#xff08;即…

【Py/Java/C++三种语言详解】LeetCode每日一题240217【二叉树BFS】LeetCode429、N叉树的层序遍历

有LeetCode交流群/华为OD考试扣扣交流群可加 948025485 可上全网独家的 欧弟OJ系统 练习华子OD、大厂真题 绿色聊天软件戳 od1336了解算法冲刺训练 文章目录 题目链接题目链接题目描述解题思路DFS和BFS异同用队列维护的BFS 代码PythonJavaC时空复杂度 相关习题华为OD算法/大厂面…

物理层计网

文章目录 前言一、物理层的基本概念1.物理层所要解决的问题2.物理层协议的主要任务 二、物理层下面的传输媒体1.导引型传输媒体2.非导引型传输媒体 三、传输方式1.串行传输和并行传输2.同步传输和异步传输3.单工、半双工、全双工传输 四、编码与调制1.数据通信中的常用术语2.编…

RM电控工程讲义

HAL_CAN_RxFifo0MsgPendingCallback(CAN_HandleTypeDef *hcan) 是一个回调函数&#xff0c;通常在STM32的HAL库中用于处理CAN&#xff08;Controller Area Network&#xff09;接收FIFO 0中的消息。当CAN接口在FIFO 0中有待处理的消息时&#xff0c;这个函数会被调用。 HAL库C…

算法刷题:长度最小的子数组

长度最小的子数组 .题目链接题目详情算法原理滑动窗口定义指针进窗口判断出窗口 我的答案 . 题目链接 长度最小的子数组 题目详情 算法原理 滑动窗口 这道题,我们采用滑动窗口的思想来解决,具体步骤如图所示 定义指针 如图所示,两个指针都需要从左往右进行遍历,因此初始值…

Python算法100例-1.6 打鱼还是晒网

1.问题描述2.问题分析3.算法设计4.确定程序框架5.求出指定日期距离1990年1月1日的天数6.完整的程序7.补充知识点 1&#xff0e;问题描述 中国有句俗语叫“三天打鱼两天晒网”。某人从1990年1月1日起便开始“三天打鱼两天晒网”&#xff0c;问这个人在以后的某一天中是“打鱼”…

Vue练习3:组件开发3(页面切换)

预览 ——————————————————————————————————————————— 组件文档 Pager组件 属性 属性名含义类型必填默认值current当前页码&#xff08;总数据量/单页容量&#xff09;Number否1total总数据量Number否0limit单页容量Number否10vis…

「算法」滑动窗口

前言 算法需要多刷题积累经验&#xff0c;所以我行文重心在于分析解题思路&#xff0c;理论知识部分会相对简略一些 正文 滑动窗口属于双指针&#xff0c;这两个指针是同向前行&#xff0c;它们所夹的区间就称为“窗口” 啥时候用滑动窗口&#xff1f; 题目涉及到“子序列…

AI大模型专题:工业大模型技术应用与发展报告1.0

今天分享的是AI大模型系列深度研究报告&#xff1a;《AI大模型专题&#xff1a;工业大模型技术应用与发展报告1.0》。 &#xff08;报告出品方&#xff1a;中国信通院&#xff09; 报告共计&#xff1a;25页 人工智能的几个相关概念 大模型&#xff1a;即基础模型&#xff…

爱上JVM——常见问题(一):JVM组成

1 JVM组成 1.1 JVM由那些部分组成&#xff0c;运行流程是什么&#xff1f; 难易程度&#xff1a;☆☆☆ 出现频率&#xff1a;☆☆☆☆ JVM是什么 Java Virtual Machine Java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09; 好处&#xff1a; 一次编写&…

批量美化图片:轻松打造统一风格的图片库!

在数字时代&#xff0c;图片已经成为我们生活中不可或缺的一部分。从朋友圈的分享到商业广告的展示&#xff0c;每一张图片都承载着我们的情感和创意。但是&#xff0c;你是否曾经因为大量的图片需要美化而感到头疼&#xff1f;是否因为繁琐的手动编辑而失去了创作的热情&#…

钡铼技术的LoRa网关实现智能电网监测与控制

钡铼技术的LoRa网关在智能电网监测与控制方面发挥着关键作用&#xff0c;为电力系统的安全运行和高效管理提供了重要支持。下面将详细介绍钡铼技术的LoRa网关如何实现智能电网监测与控制。 首先&#xff0c;钡铼技术的LoRa网关通过接入各类传感器和监测设备&#xff0c;实现对…

C++11---(1)

目录 一、C11简介 二、列表初始化 2.1、{ } 初始化 三、变量类型推导 3.1、auto 3.2、decltype 为什么需要decltype 四、final和override 4.1、final 4.2、override 五、默认成员函数控制 5.1、default修饰函数 5.2、delete修饰函数 六、nullptr 一、C11简介 C11是…
最新文章