news 2026/4/18 14:28:32

分数取模的应用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
分数取模的应用

这是牛客寒假营第一场的A题,这是我第一次接触分数取模的题,从这里面学到了分数取模以及乘法逆元的相关知识。

我的整体思路就是定义两个数组p1和p2,其中p1中存放的是1-7个灯管亮的概率,p2中存放的是1-7个灯管不亮的概率。其中就用到了分数取模操作。其中用到了快速幂算法。接着在基于当前每个灯管亮的概率下,再去分别计算每个数字亮的概率,最后在将所有满足A + B = C的形式的 数的概率加起来就能得到最终的答案。我觉得难点主要是在分数取模这一步。

分数取模的具体解释如下:

具体代码如下:

#include <bits/stdc++.h> #define MOD 998244353 #define ll long long using namespace std; //a的b次方 ll qkm(ll a,ll b){ ll ans = 1; ll base = a; while (b){ if (b & 1){ ans = (ans * base) % MOD; } b >>= 1; base = (base * base) % MOD; } return ans; } void solve(){ ll c; cin>>c; //p1是1-7灯管亮的概率,p2是1-7灯管不良的概率 vector<ll> p1(8),p2(8); for (int i = 1;i <= 7;++i){ ll x; cin>>x; p1[i] = (x * qkm(100,MOD - 2)) % MOD; p2[i] = (1 - p1[i] + MOD) % MOD; // cout<<p1[i]<<" ! "<<p2[i]<<endl; } vector<ll> abc(10); vector<vector<ll>> num(10,vector<ll> (10));//每个数字亮的概率p num[0][1] = num[0][1] = num[0][2] = num[0][3] = num[0][5] = num[0][6] = num[0][7] = 1; num[1][3] = num[1][6] = 1; num[2][1] = num[2][3] = num[2][4] = num[2][5] = num[2][7] = 1; num[3][1] = num[3][3] = num[3][4] = num[3][6] = num[3][7] = 1; num[4][2] = num[4][3] = num[4][4] = num[4][6] = 1; num[5][1] = num[5][2] = num[5][4] = num[5][6] = num[5][7] = 1; num[6][1] = num[6][2] = num[6][4] = num[6][5] = num[6][6] = num[6][7] = 1; num[7][1] = num[7][3] = num[7][6] = 1; num[8][1] = num[8][2] = num[8][3] = num[8][4] = num[8][5] = num[8][6] = num[8][7] = 1; num[9][1] = num[9][2] = num[9][3] = num[9][4] = num[9][6] = num[9][7] = 1; for (int i = 0;i <= 9;++i){ ll ss = 1; for (int j = 1;j <= 7;++j){ if (num[i][j] == 1){ ss = (ss * p1[j]) % MOD; } else{ ss = (ss * p2[j]) % MOD; } } abc[i] = ss; } ll fz = 0; for (int i = 0;i <= c;++i){ ll sh = 1; ll g,s,b,q; g = i % 10; s = i % 100 / 10; b = i % 1000 / 100; q = i / 1000; sh = (sh * abc[g]) % MOD; sh = (sh * abc[s]) % MOD; sh = (sh * abc[b]) % MOD; sh = (sh * abc[q]) % MOD; g = (c - i) % 10; s = (c - i) % 100 / 10; b = (c - i) % 1000 / 100; q = (c - i) / 1000; sh = (sh * abc[g]) % MOD; sh = (sh * abc[s]) % MOD; sh = (sh * abc[b]) % MOD; sh = (sh * abc[q]) % MOD; if (fz == 0){ fz = sh; } else{ fz = (fz + sh) % MOD; } } cout<<fz<<endl; } int main() { int t; cin>>t; while (t--){ solve(); } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:48:29

咕噜分发——APP图标在线制作

咕噜分发&#xff08;gulufenfa.com&#xff09;的APP图标在线制作工具是该平台提供的一项实用功能&#xff0c;主要面向APP开发者、测试人员及企业用户&#xff0c;用于快速生成符合iOS/Android平台规范的APP图标资源包。以下是该功能的详细介绍&#xff1a; 一、功能定位与核…

作者头像 李华
网站建设 2026/4/17 16:50:41

小程序商城开发要点解析:从核心架构到关键功能模块

伴随着移动互联网朝着 方向发展&#xff0c;小程序商城已然变成零售、餐饮、本地生活等好些行业用以开展数字化转型的标准配备。和传统的独立 APP 或者 H5 页面相比较而言&#xff0c;小程序靠着它那“无需下载、即用即走”的轻量化特有属性&#xff0c;以及借助微信、支付宝等…

作者头像 李华
网站建设 2026/4/18 6:45:54

计算机PHP毕设实战-基于php+vue的动物救助网站的设计与实现基于php+vue.js流浪动物宠物领养公益网站【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/18 8:42:30

工业互联网平台有哪些技术支持

工业互联网平台作为支撑制造业数字化、网络化、智能化转型的新型基础设施&#xff0c;其技术支撑体系涵盖多个层面&#xff0c;以下从核心架构、关键技术、新兴技术融合三个维度展开分析&#xff1a;一、核心架构支撑&#xff1a;分层技术体系工业互联网平台通常采用边缘层、Ia…

作者头像 李华
网站建设 2026/4/18 5:41:26

[信息论与编码理论专题-16]:等概率时熵最大、编码最长;实际概率不均,熵降低,变长编码可压缩,平均码长更短。

在一个包含 N 个可能事件的系统中&#xff0c;当所有事件等概率发生时&#xff0c;系统的熵达到最大值 log 2​N &#xff0c;此时对事件进行最优无损编码所需的平均码长也达到理论最大值。 而在实际系统中&#xff0c;事件发生的概率往往不相等&#xff1b;若存在较多高概率事…

作者头像 李华
网站建设 2026/4/18 1:44:39

跟AI学一手之自定义调试函数或者类

最后一招是 macos 专用的&#xff0c;有帮助&#xff0c;所以记录一下 from gevent import monkey monkey.patch_all() import signal import sys import os# 检查是否有信号处理 def debug_signal(signum, frame):print(f"收到信号 {signum}&#xff0c;堆栈:", fi…

作者头像 李华