2024杭电多校第五场

news2025/2/24 19:57:32

第一题:开关灯

直接暴力找规律。

发现如果n==2(mod3)那么就是2的n-1次方。否则直接是2的n次方。

暴力代码

#include<bits/stdc++.h>
using namespace std;
#define int long long



signed main() {

	int temp[100];
	temp[0] = 1;
	for (int i = 1; i <= 20; i++) {
		temp[i] = temp[i - 1] * 2;
	}
	
	for (int i = 2; i <= 20; i++) {
		set<string>s;
		s.clear();
		string ans;
		string tt;
		for (int j = 0; j < temp[i]; j++) {
			tt += '0';
		}
		ans=tt;
		s.insert(ans);
		for (int j = 0; j <= temp[i]; j++) {
			ans=tt;
			for (int k = 0; k < i; k++) {
				if (j & 1 << k) {
					if (k == 0) {
						if (ans[k] == '0') ans[k] = '1';
						else ans[k] = '0';
						if (ans[k + 1] == '0') ans[k + 1] = '1';
						else ans[k + 1] = '0';
					} else if (k == i - 1) {
						if (ans[k] == '0') ans[k] = '1';
						else ans[k] = '0';
						if (ans[k - 1] == '0') ans[k - 1] = '1';
						else ans[k - 1] = '0';
					} else {
						if (ans[k] == '0') ans[k] = '1';
						else ans[k] = '0';
						if (ans[k - 1] == '0') ans[k - 1] = '1';
						else ans[k - 1] = '0';
						if (ans[k + 1] == '0') ans[k + 1] = '1';
						else ans[k + 1] = '0';
					}
				}
				
			}
			s.insert(ans);
		}
		cout<<i<<"    "<<s.size()<<endl;
	}



}

第二题:飞行棋

就是分成两部分,一部分是求得0号点。

另外一部分就是其他的点。

在0号点的时候有 1/n的概率直接到达终点

在其他点的时候有1/(n-1)的概率可以直接到达。(有两种理解方式)

第一种理解方式:求和公式,pi代表成功的概率。

第二种理解方式是按照题意。 1/n+1/n*1/(n-1) 

然后求最后的期望。

其中0号点的期望值就是 1/n

其他点的期望可以看成几何分布。 伯努利实验的几何分布。期望直接就是 n-1;

最后求得结果。 为 1/n+n-1



#include <bits/stdc++.h>

using namespace std;

#define int128 __int128_t
#define int long long
#define PII pair<int, int>
#define PDD pair<double, double>
#define fi first    
#define se second
#define lowbit(x) x & -x
#define all(x) x.begin(), x.end()
#define INF 0x3f3f3f3f3f3f3f3f
#define ls(x) x << 1
#define rs(x) x << 1 | 1

const int N = 3e5 + 10, M = 5e6 + 10, mod = 998244353;
const double eps = 1e-8;

int t, n, m, k, lim, res;
string sr;

int gcd(int a, int b) {
    return b ? gcd(b, a % b) : a;
}

int ksm(int a,int b){
	int res=1;
	while(b){
		if(b&1) res=res*a%mod;
		a=a*a%mod;
		b>>=1;
	}
	return res;
}
void solve() {
   cin>>n;
   int res=n-1+ksm(n%mod,mod-2);
   res=(res+mod)%mod;
   cout<<res%mod<<endl;
}

signed main() {
    cin.tie(nullptr)->sync_with_stdio(false);
    // cout.setf(ios::fixed), cout.precision(4);
    t = 1;
    cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}

第三题:猫猫的罐头游戏

通过找规律,可以发现 三个数字相同一定是必败态

三个数字都是奇数也是必败态

直接猜测,1 奇 奇的时候是必败状态。1+奇是偶数。第三个数字可以随意选择。(把第三个数字删除,然后另外一个数字转换成1+奇的状态)。

那么奇偶奇 奇偶偶是必胜态 奇奇奇是必败态。

然后观察偶偶偶的状态。

#include <bits/stdc++.h>
using namespace std;

int main() {
    int T = 1;
    cin >> T;
    while (T --) {
        int a, b, c, fa, fb, fc;
        
        cin >> a >> b >> c;
        fa = a / 2;  fb = b / 2;  fc = c / 2;  a %= 2; b %= 2; c %= 2;
        if (a + b + c != 0 && a + b + c != 3) {
            cout << "YES\n";
        } else if (a + b + c == 3) {
            cout << "NO\n";
        } else {
            while (fa % 2 == 0 && fb % 2 == 0 && fc % 2 == 0) {
                fa /= 2;  fb /= 2; fc /= 2;
            }
            fa %= 2;  fb %= 2;  fc %= 2;
            if (fa + fb + fc == 3) {
                cout << "NO\n";
            } else {
                cout << "YES\n";
            }
        }
    }
    return 0;
}

第四题:array-gift

其实就是判断这几种情况

求两个gcd,一个gcd1是去重之后的所有数。一个gcd2是去重之后去了最小的数字的gcd。

如果gcd1=最小的数字,那么肯定就是n-1

如果后面有数字 a[j]%a[i]==gcd1 那么肯定就可以直接 n步

如果gcd2>最小的数字。同样也可以是n

否则就是n+1;



#include <bits/stdc++.h>

using namespace std;

#define int128 __int128_t
#define int long long
#define PII pair<int, int>
#define PDD pair<double, double>
#define fi first    
#define se second
#define lowbit(x) x & -x
#define all(x) x.begin(), x.end()
#define INF 0x3f3f3f3f3f3f3f3f
#define ls(x) x << 1
#define rs(x) x << 1 | 1

const int N = 3e5 + 10, M = 5e6 + 10, mod = 998244353;
const double eps = 1e-8;

int t, n, m, k, lim, res;
string sr;

int gcd(int a, int b) {
    return b ? gcd(b, a % b) : a;
}

int ksm(int a,int b){
	int res=1;
	while(b){
		if(b&1) res=res*a%mod;
		a=a*a%mod;
		b>>=1;
	}
	return res;
}
int a[N];
void solve() {
    int n;
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i];
    sort(a+1,a+1+n);
    vector<int>b;
    vector<int>vis(N,0);
    int gcd1,gcd2;
    for(int i=1;i<=n;i++){
    	if(vis[i]) continue;
    	b.push_back(a[i]);
		for(int j=i+1;j<=n;j++)
		{
			if(a[j]%a[i]==0)
			{
				vis[j]=true;
			}
		}
	}
	sort(b.begin(),b.end());
	gcd1=b[0];
	gcd2=b[1];
	
	for(int i=1;i<b.size();i++)
	{
		gcd1=gcd(gcd1,b[i]);
		gcd2=gcd(gcd2,b[i]);
	}
    if(gcd1==b[0]){
		cout<<n-1<<endl;return ;
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=i+1;j<=n;j++)
		{
			if(a[j]%a[i]==gcd1){
				cout<<n<<endl;
				return ;
			}
		}
	}
	if(gcd2>b[0]) cout<<n<<endl;
	else cout<<n+1<<endl;
    
}

signed main() {
    cin.tie(nullptr)->sync_with_stdio(false);
    // cout.setf(ios::fixed), cout.precision(4);
    t = 1;
    cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}

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

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

相关文章

SOMEIP_ETS_001:数组长度超过消息长度允许的范围

测试目的&#xff1a; 验证DUT&#xff08;Device Under Test&#xff0c;被测设备&#xff09;在接收到数组长度超过SOME/IP协议允许的最大长度时&#xff0c;是否能够返回错误消息。 描述 本测试用例旨在检查DUT在接收到一个SOME/IP消息时&#xff0c;如果该消息中的数组长…

Java学习:今日成果,明日挑战

阅读指南&#xff1a;[题目] - 精选摘要 题目1.面向对象编程意味着2.以下哪项不是 Java 关键字&#xff1f;3.基础数据类型在堆栈上分配&#xff1f;4.以下代码将导致&#xff1a;5.以下输出是什么 &#xff1f;6.如果我们声明&#xff1a;7.Java 使用按值调用。 以下方法调用传…

S7-1200PLC 和8块欧姆龙温控表MODBUS通信(完整SCL代码)

1、如何提升MODBUS-RTU通信数据的刷新速度 提升MODBUS-RTU通信数据刷新速度的常用方法_modbus rtu通讯慢-CSDN博客文章浏览阅读1.2k次。SMART PLC的MODBUS-RTU通信请参考下面文章链接:【精选】PLC MODBUS通信优化、提高通信效率避免权限冲突(程序+算法描述)-CSDN博客MODBU…

MATLAB预测模型(1)

一、前言 在MATLAB中&#xff0c;解决和预测微分方程通常涉及到使用数值方法&#xff0c;因为许多微分方程的解析解是难以找到的。MATLAB提供了多种函数和工具箱来处理这类问题&#xff0c;其中ode45是最常用的一个&#xff0c;用于求解非刚性微分方程的初值问题。 二、实现 以…

Linux中DHCP服务器配置和管理

文章目录 一、DHCP服务1.1、DHCP的工作流程1.2、DHCP的工作模式1.3、dhcp的主要配置文件 二、安装DHCP服务2.1、更新yum源2.2、安装DHCP服务软件包2.3、配置DHCP服务2.4、启用DHCP服务&#xff08;解决报错&#xff09;2.4.1、查看dhcpd服务的状态和最近的日志条目2.4.2、查看与…

代码随想录27天|贪心

455.分发饼干 代码随想录 第一想法 将孩子胃口值g[i] 按从小到达的顺序排列&#xff0c;饼干尺寸也按照从小到大的顺序去排列。 优先将大尺寸喂给大胃口孩子。如果满足不了胃口那么久试着分给下一个孩子。 要尽量满足更多的孩子&#xff0c;那么大尺寸的饼干就不能喂给小胃口…

PMP–知识卡片--燃起图

燃起图用两条曲线分别绘制随时间的推移、完成的工作量和总工作量的变化情况。它不仅能清晰地展示项目进度&#xff0c;还是对团队成员的一种激励形式。 使用燃起图可以更好地了解进度、范围变更和预期完成时间&#xff0c;它为所有相关方提供了更清晰的进度状态。 燃起图根据工…

抖音豆包大模型AI写作教程

简数采集器支持调用字节跳动抖音的豆包AI大模型API接口&#xff0c;用于对采集的数据进行研究分析&#xff0c;内容写作等。 抖音豆包大模型AI写作使用教程&#xff1a; 目录 1.启用豆包AI大模型API功能 2.设置豆包API处理规则 3.应用API规则处理数据 4.获取AI处理结果 1…

算法 一

时间复杂度 常数操作&#xff1a;和数量无关&#xff0c;每次都是固定时间内完成。 只要高阶项&#xff0c;也不要高阶项的系数。 选择排序、冒泡排序 选择排序&#xff1a;以第一位为起点&#xff0c;每次选择最小的数放在最前面&#xff0c;起点向后挪一位。 冒泡排序&…

冰山的崛起:数据架构的转变

像 Apache Iceberg、Apache Hudi 和 Delta Lake 这样的开放表格式已成为查询处理器的事实标准。然而&#xff0c;最近有消息称 Snowflake 和 Databricks 等查询引擎采用了 Iceberg 的 REST 目录 API&#xff0c;这改变了竞争环境&#xff0c;有利于 Iceberg。 Iceberg的成功不仅…

国内自闭症学校:寻找最适合您孩子的选择

当您的孩子被诊断为自闭症&#xff0c;为他们寻找一所合适的学校就成为了您至关重要的任务。在国内&#xff0c;有各种各样的自闭症学校&#xff0c;每所学校都有其独特的特点和优势。然而&#xff0c;如何在众多的选择中找到最适合您孩子的那一所&#xff0c;并非易事。 您需要…

【数据结构算法经典题目刨析(c语言)】顺序表和链表的区别(图文详解)

&#x1f493; 博客主页&#xff1a;C-SDN花园GGbond ⏩ 文章专栏&#xff1a;数据结构经典题目刨析(c语言) 目录 顺序表和链表的区别 一、底层存储空间 二、插入和删除操作 三、随机访问 四、空间利用率 五、应用场景 六、高速缓存 为什么顺序表的缓存利用率高于链表呢…

windows 文件夹下的文件名称全部输入到txt文件中(已解决)

打开cmd 命令行&#xff0c;记住一定是cmd命令行 进入cmd 目前在C盘&#xff0c;跳转D盘&#xff0c;输入d:。 d: 回车&#xff1b; 在输入或者粘贴你的目的路径 我的是 D:\opencv****\build\x64\vc14\lib&#xff0c;回车进入目的路径。 然后 再输入&#xff1a;dir /b &…

windows环境下安装docker与jenkins进行单机简易安装

CI/CD流水线简易实战 技术工具: Git Jenkins Docker Git Git是一个开源的分布式版本控制系统&#xff0c;用于敏捷高效地处理任何规模的项目。 GitHub是在线的基于Git的代码托管服务。GitHub于2008年由Ruby on Rails编写而成。GitHub同时提供付费账户和免费账户。这两种账户都…

包装类(String、StringBuffer、StringBuilder) 重点

包装类&#xff08;Wrapper Class&#xff09;是Java中的一个重要概念&#xff0c;它们是用于将基本数据类型&#xff08;如int, char, double等&#xff09;封装成对象的类。使用包装类的主要目的是为了能够更好地与Java的集合框架&#xff08;如ArrayList、HashMap等&#xf…

Modelsim仿真之VCD文件详解

目录 一、前言 二、VCD文件格式 2.1 头部 2.2 变量定义 ​ 2.3 值打印 2.4 值变化部分 2.5 VCD文件示例 三、VCD文件生成 3.1 工程代码 3.2 modelsim操作 3.3 VCD结果查看 3.4 VCD类型2 四、参考资料 一、前言 ​VCD&#xff08;Value change dump&#xff09;…

mv:自动对焦代码

try:# The camera will now focus on whatever is in front of it.sensor.ioctl(sensor.IOCTL_TRIGGER_AUTO_FOCUS) except:raise (Exception("Auto focus is not supported by your sensor/board combination."))

说说ip地址和mac地址的区别

随着互联网的飞速发展&#xff0c;网络连接已成为我们日常生活中不可或缺的一部分。然而&#xff0c;在享受网络带来的便利时&#xff0c;你是否曾好奇过那些让设备能够相互通信的关键技术&#xff1f;IP地址与MAC地址&#xff0c;作为网络通信中的两大基石&#xff0c;它们各自…

2023华为od机试C卷【API集群负载统计】Python实现

思路 统计第二层级上computing出现的次数的时候&#xff0c;只需要for循环寻找computing是否在字典的键中。 如果找到&#xff0c;计数的时候是加上computing对应的值 def main():import collectionslength_char int(input())node_info {}for i in range(length_char):char…

### 微软的传奇与未来:从车库到云端的飞跃

今天我要和大家聊聊科技界的超级明星——微软。这家公司几乎每个人都听过&#xff0c;从90年Windows全家桶&#xff0c;到现在的云端革命&#xff0c;微软的故事简直有点儿像科技界的“美国梦”。 #### **车库里的梦想** 一切都得从1975年说起。当时&#xff0c;比尔盖茨和保…