笔试——Day43

文章目录

第一题

题目

kotori和抽卡(二)

思路

数学: 二项分布C(n, m) * p ^ n * (1 - p) ^ m

代码

cpp 复制代码
#include<iostream>
using namespace std;

int n, m;

int main()
{
    cin >> n >> m;
    double res = 1.0;
    for(int i = n; i >= n - m + 1; i--) res *= i;
    for(int i = m; i >= 1; i--) res /= i;
    for(int i = 0; i < m; i++) res *= 0.8;
    for(int i = 0; i < n - m; i ++) res *= 0.2;
    
    printf("%.4f\n", res);
    
    return 0;
}

第二题

题目

ruby和薯条

思路 1

  • 排序数组:首先对数组进行排序
  • 遍历每个元素作为基准:对于每个元素a[i],寻找所有满足条件的a[j]
  • 使用二分查找确定范围
    • 找到第一个 ≥ a[i] + l 的位置(左边界)
    • 找到第一个 > a[i] + r 的位置(右边界)
  • 统计对数:两个边界之间的元素个数就是满足条件的对数

代码1

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;

const int N = 200010;

int n, l, r;
int a[N];

int main() {
    cin >> n >> l >> r;
    for (int i = 0; i < n; i++) cin >> a[i];
    sort(a, a + n);
    
    long long res = 0;
    for (int i = 0; i < n - 1; i++) 
    {
        int left_bound = a[i] + l;
        int right_bound = a[i] + r;
        // 找到第一个大于等于left_bound的位置
        int j = lower_bound(a + i + 1, a + n, left_bound) - a;
        // 找到第一个大于right_bound的位置
        int k = upper_bound(a + i + 1, a + n, right_bound) - a;
        res += (k - j);
    }
    
    cout << res << endl;
    
    return 0;
}

思路2

  • [l, r]之间⼀共有多少对等价于[0,r] - [0, l -1]有多少对
  • 利用滑动窗口解决[0, x]有多少对;

代码2

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;

const int N = 200010;

int n, l, r;
int a[N];

// 找出差值在 [0, x] 之间⼀共有多少对
long long solve(int x)
{
    long long res = 0;
    int left = 0, right = 0;
    while(right < n)
    {
        while((a[right] - a[left]) > x) left++;
        res += right - left;
        right++;
    }
    return res;
}

int main() 
{
    cin >> n >> l >> r;
    for (int i = 0; i < n; i++) cin >> a[i];
    sort(a, a + n);
    
    cout << solve(r) - solve(l - 1) << endl;
    
    return 0;
}

第三题

题目

循环汉诺塔

思路

模拟找规律

代码

cpp 复制代码
#include <iostream>
using namespace std;

const int MOD = 1000000007;

int n;

int main() 
{
    cin >> n;
    int x = 1, y = 2;
    for(int i = 2; i <= n; i++)
    {
        int xx = 2 * y % MOD + 1;
        int yy = (2 * y % MOD + 2 + x) % MOD;
        x = xx;
        y = yy;
    }
    cout << x << " " << y << endl;

    return 0;
}
// 64 位输出请用 printf("%lld")
相关推荐
小李独爱秋11 分钟前
机器学习中的聚类理论与K-means算法详解
人工智能·算法·机器学习·支持向量机·kmeans·聚类
liu****34 分钟前
负载均衡式的在线OJ项目编写(六)
运维·c++·负载均衡·个人开发
青草地溪水旁1 小时前
设计模式(C++)详解——迭代器模式(3)
c++·设计模式·迭代器模式
奔跑吧邓邓子1 小时前
【C++实战㊺】解锁C++代理模式:从理论到实战的深度剖析
c++·实战·代理模式
杜子不疼.1 小时前
【C++】玩转模板:进阶之路
java·开发语言·c++
夜晚中的人海2 小时前
【C++】异常介绍
android·java·c++
m0_552200822 小时前
《UE5_C++多人TPS完整教程》学习笔记60 ——《P61 开火蒙太奇(Fire Montage)》
c++·游戏·ue5
charlie1145141912 小时前
精读C++20设计模式——行为型设计模式:迭代器模式
c++·学习·设计模式·迭代器模式·c++20
小欣加油2 小时前
leetcode 1863 找出所有子集的异或总和再求和
c++·算法·leetcode·职场和发展·深度优先
十八岁讨厌编程2 小时前
【算法训练营Day27】动态规划part3
算法·动态规划