Day 4:牛客周赛Round 91

好久没写了,问题还蛮多的。听说这次是苯环哥哥出题
F题 小苯的因子查询
思路

考虑求因子个数,用质因数分解;奇数因子只需要去掉质数为2的情况,用除法。
这里有个比较妙的细节是,提前处理出数字x的最小质因数,当然不处理也没关系。

我出的bug

  • 忘记逆元怎么求了,甚至连名字都忘记了,想了一会才想起来
  • 1e6的读入,忘记禁用同步和解除绑定了
  • const int mod=998244353; 少了const
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define ft first
#define sd second
const int mod=998244353;
const int N=1e6+10;
int prime[N],kk,vis[N];
pair<int,int> ans[N];//记录第i个的奇数个数,因子个数
int total[N];//质因子为i的次幂int power(int x,int y)
{int res=1;while(y){if(y&1) res=res*x%mod;y/=2;x=x*x%mod;}return res%mod;
}
int inv(int y) {return power(y,mod-2);}
void Prime()
{for(int i=2;i<N;i++){if(vis[i]==0) prime[++kk]=i,vis[i]=kk;for(int j=i+i;j<N;j+=i){if(vis[j]==0) vis[j]=kk;//vis记录最小质因数的编号,编号从1开始}}
}
void init()
{Prime();ans[1].ft=ans[1].sd=1;for(int i=2;i<N;i++)//递推,更新下一个ans{int j=vis[i],tmp=i;while(j>0){int cnt=0;while(tmp%prime[j]==0)cnt++,tmp/=prime[j];if(total[prime[j]]==0)//增加一个质因子的情况{ans[i].sd=ans[i-1].sd*(cnt+1)%mod;}else //已有质因子的情况{ans[i].sd=ans[i-1].sd*inv(total[prime[j]]+1)%mod*(total[prime[j]]+cnt+1)%mod;}total[prime[j]]+=cnt;j=vis[tmp];}ans[i].ft=ans[i].sd*inv(total[2]+1)%mod;}
}
int solve(int n)
{int x=ans[n].ft;int y=ans[n].sd;int inv_y=inv(y);//cout<<x<<" "<<y<<" ";return x*inv_y%mod;}
signed main()
{//ios::sync_with_stdio(false);cin.tie(0);init();int n,t;ios::sync_with_stdio(0);cin.tie(0);cin>>t;while(t--){cin>>n;cout<<solve(n)<<" ";}return 0;
}

一般大佬的Coding:

#include <bits/stdc++.h>
using namespace std;
using u32 = unsigned int;
using i64 = long long;
using u64 = unsigned long long;
#define int long long
#define rep(i, a, b) for (int (i) = (a); (i) <= (b); ++i)
#define rep2(i, a, b) for (int (i) = (a); (i) >= (b); --i)
#define debug(x) std::cout << #x << " : " << x << "\n";
#define debug2(x,y) std::cout << #x << " : " << x << " " << #y << " : " << y << "\n";
const int MOD = 998244353;
const int N = 1e6 + 10;
long long power(long long a, int b, int p) {long long res = 1;while (b) {if (b & 1) res = res * a % p;b >>= 1;a = a * a % p;}return res;
}
long long inv(int x) { return power(x, MOD - 2, MOD); }
int fac[N];
void init() {fac[0] = 0;for (int i = 1; i <= N - 1; i++) {fac[i] = fac[i - 1] + __builtin_ctz(i);}
}
void solve()
{int n; cin >> n;cout << inv(fac[n] + 1) << " ";
}
signed main()
{std::ios::sync_with_stdio(false);// cout<<std::fixed<<std::setprecision(10);std::cin.tie(0);init();int t__ = 1;cin >> t__;while (t__--)solve();return 0;
}

D题 数组4.0
思路

排序分段,段和段之间只需一条边即可连接;段和单点之间需要再考虑单点内部连接。

#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
int n,m;
int b[N],cnt[N];
int ans=0;void solve()
{if(n==1){cout<<0<<"\n";return ;}//只有一个数sort(b,b+n);m=unique(b,b+n)-b;if(m==1){cout<<n-1<<"\n";return ;}//只有一个元素ans=0;bool p=0;// p==1时,说明这是一段的左边或者内部,而不是单点for(int i=1;i<m;i++){if(b[i]-b[i-1]==1){p=1;continue;}ans++;if(p==0) ans+=cnt[b[i-1]]-1; //说明上一段结束,此时也结束,说明上个点是单点p=0;}if(p==0)ans+=cnt[b[m-1]]-1;//单点cout<<ans<<"\n";}
signed main()
{int t;cin>>t;while(t--){for(int i=0;i<N;i++)cnt[i]=0;cin>>n;for(int i=0;i<n;i++)cin>>b[i],cnt[b[i]]++;solve();}return 0;
}
/*
1
7
1 2 4 4 6 7 8 
*/

小苯的逆序对和
思路

简单的思维题,直觉双指针,然后把自己绕进去,最后画座多峰的山就好理解了。
l 找峰顶,mx记录当前最高的峰顶,j作为指针,遍历完满足当前低于最高峰顶mx的最大答案,否则继续更新l

#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
int n,m;
int b[N],cnt[N];
int ans=0;void solve()
{int l=0,r=n-1;ans=0;int mx=b[l];while(l<r){while(l<r&&b[l]<b[l+1])l++;//左边找这一段最大的,山峰if(l==r)break;mx=max(mx,b[l]);//此时最高的山峰int j=l+1;while(j<=r&&mx>b[j]){ans=max(mx+b[j],ans);j++;}l=j;}cout<<ans<<'\n';
}
signed main()
{int t;cin>>t;while(t--){cin>>n;for(int i=0;i<n;i++)cin>>b[i];solve();}return 0;
}
/*
1
7
1 2 4 4 6 7 8 
*/

B题 token

前缀和,检查两遍才发现忘记开long long了,代码就不展示了。

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

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

相关文章

使用直觉理解不等式

问题是这个&#xff1a; 题目 探究 ∣ max ⁡ b { q 1 ( z , b ) } − max ⁡ b { q 2 ( z , b ) } ∣ ≤ max ⁡ b ∣ q 1 ( z , b ) − q 2 ( z , b ) ∣ |\max_b\{q_1(z,b)\}-\max_b\{q_2(z,b)\}|\le\max_b|q_1(z,b)-q_2(z,b)| ∣maxb​{q1​(z,b)}−maxb​{q2​(z,b)}∣≤…

恶心的win11更新DIY 设置win11更新为100年

‌打开注册表编辑器‌&#xff1a;按下Win R键&#xff0c;输入regedit&#xff0c;然后按回车打开注册表编辑器。‌12‌导航到指定路径‌&#xff1a;在注册表编辑器中&#xff0c;依次展开HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings‌新建DWORD值‌&…

嵌入式驱动学习

时钟 定义 周期型的0、1信号 时钟信号由“心脏”时钟源产生&#xff0c;通过“动脉”时钟树传播到整个芯片中。 SYSCLK系统时钟&#xff0c;由HSI、HSE、PLLCLK三选一。 HCLK是AHB总线时钟&#xff0c; PCLK是APB总线时钟。 使用某个外设&#xff0c;必须要先使能该外设时钟系统…

Java:从入门到精通,你的编程之旅

Java&#xff0c;一门历久弥新的编程语言&#xff0c;自诞生以来就以其跨平台性、面向对象、稳定性和安全性等特性&#xff0c;在企业级应用开发领域占据着举足轻重的地位。无论你是初学者还是经验丰富的开发者&#xff0c;Java 都能为你提供强大的工具和广阔的舞台。 为什么选…

Linux:深入理解数据链路层

实际上一台主机中&#xff0c;报文并没有通过网络层直接发送出去&#xff0c;而是交给了自己的下一层协议——数据链路层&#xff01;&#xff01; 一、理解数据链路层 网络层交付给链路层之前&#xff0c;会先做决策再行动&#xff08;会先查一下路由表&#xff0c;看看目标网…

Python基本语法(类和实例)

类和实例 类和对象是面向对象编程的两个主要方面。类创建一个新类型&#xff0c;而对象是这个 类的实例&#xff0c;类使用class关键字创建。类的域和方法被列在一个缩进块中&#xff0c;一般函数 也可以被叫作方法。 &#xff08;1&#xff09;类的变量&#xff1a;甴一个类…

2025 年如何使用 Pycharm、Vscode 进行树莓派 Respberry Pi Pico 编程开发详细教程(更新中)

micropython 概述 micropython 官方网站&#xff1a;https://www.micropython.org/ 安装 Micropython 支持固件 树莓派 Pico 安装 Micropython 支持固件 下载地址&#xff1a;https://www.raspberrypi.com/documentation/microcontrollers/ 选择 MicroPython 下载 RPI_PIC…

flink rocksdb状态说明

文章目录 1.默认情况2.flink中的状态3.RocksDB4.对比情况5.使用6.RocksDB架构7.参考文章8.总结提示:以下主要考虑flink 状态永久存储 rocksdb情况,做一些简单说明 1.默认情况 当flink使用rocksdb存储状态时。无论是永久存储还是临时存储都可能会落盘写文件(如果没有配置存储…

安装SDL和FFmpeg

1、先记录SDL 这玩意还是有一点讲究的 具体步骤&#xff1a; 下载 SDL包&#xff1a; 链接&#xff1a;https://www.libsdl.org/release/SDL2-2.0.14.tar.gz 可以用迅雷&#xff0c;下载完之后&#xff0c; 解压&#xff1a; tar -zxvf SDL2-2.0.14.tar.gz进入安装目录 cd …

2022年408真题及答案

2022年计算机408真题 2022年计算机408答案 2022 408真题下载链接 2022 408答案下载链接

Spring AI聊天模型API:轻松构建智能聊天交互

Spring AI聊天模型API&#xff1a;轻松构建智能聊天交互 前言 在当今数字化时代&#xff0c;智能聊天功能已成为众多应用程序提升用户体验、增强交互性的关键要素。Spring AI的聊天模型API为开发者提供了一条便捷通道&#xff0c;能够将强大的AI驱动的聊天完成功能无缝集成到…

Softmax回归与单层感知机对比

(1) 输出形式 Softmax回归 输出是一个概率分布&#xff0c;通过Softmax函数将线性得分转换为概率&#xff1a; 其中 KK 是类别数&#xff0c;模型同时计算所有类别的概率。 单层感知机 输出是二分类的硬决策&#xff08;如0/1或1&#xff09;&#xff1a; 无概率解释&#x…

【React】Hooks 解锁外部状态安全订阅 useSyncExternalStore 应用与最佳实践

一、背景 useSyncExternalStore 是 React 18 引入的一个 Hook&#xff1b;用于从外部存储&#xff08;例如状态管理库、浏览器 API 等&#xff09;获取状态并在组件中同步显示。这对于需要跟踪外部状态的应用非常有用。 二、场景 订阅外部 store 例如(redux,mobx,Zustand,jo…

Dify框架面试内容整理-如何评估基于Dify开发的AI应用的效果?

评估基于 Dify 开发的 AI 应用效果,需要从 用户体验、技术性能 与 业务价值 三个层面综合衡量。以下是详细的评估框架,涵盖三个关键点: 用户反馈与满意度

Linux 系统下VS Code python环境配置!

Anaconda安装&#xff1a; 在 Linux 系统中安装下载好的 Anaconda3-2024.10-1-Linux-x86_64.sh&#xff0c;可按以下步骤操作&#xff1a; 1. 赋予安装脚本执行权限 打开终端&#xff0c;切换到安装包所在目录&#xff08;假设在 software 文件夹中&#xff09;&#xff0c;…

项目实战-基于信号处理与SVM机器学习的声音情感识别系统

目录 一.背景描述 二.理论部分 三.程序设计 编程思路 流程图 1.信号部分 创建数据 generate_samples.py 头文件 生成函数 generate_emotion_sample 传入参数 存储路径 生成参数 创建基础正弦波信号 调制基础正弦波 对于愤怒可以增加噪声 归一化信号 存储 主函…

虚幻引擎作者采访

1万小时编程_哔哩哔哩_bilibili https://www.youtube.com/watch?v477qF6QNSvc 提姆斯温尼是一位传奇性的视频游戏程序员&#xff0c;Epic Games 的创始人兼首席执行官。 该公司开发了虚幻引擎、堡垒之夜、战争机器、虚幻竞技场等许多开创性和有影响力的视频游戏。 他哥哥…

如何限制pod 进程/线程数量?

在 Kubernetes 中限制 Pod 的 进程数&#xff08;PID 数量&#xff09; 和 线程数&#xff0c;需要结合 Linux cgroup 控制 和 容器运行时配置。以下是具体方法和示例&#xff1a; 一、限制进程数&#xff08;PID 数量&#xff09; 1. 通过 pids cgroup 控制器限制 原理&…

使用 Hugging Face 镜像站快速下载大模型

在国内使用 Hugging Face 下载模型时&#xff0c;经常遇到连接慢、断点续传失败等问题。本文记录一个稳定、快速下载模型的命令行脚本&#xff0c;并支持设置模型缓存路径和目标目录&#xff0c;方便后续统一管理。 1. 设置 Hugging Face 镜像站 为了提升国内访问速度&#xf…

原语的使用

1、什么是原语&#xff1f;&#xff1f; 原语&#xff08; primitive &#xff09;&#xff0c;是FPGA开发环境所提供的一系列逻辑功能单元。往往与FPGA芯片的厂家精密相连&#xff0c;不同厂家的原语往往不能通用。 2、需要使用原语的情况 一般来说&#xff0c;在进行HDL cod…