[题解]2023CCPC黑龙江省赛 - Ethernet

Intro

  • 来源:E.Ethernet - Codeforces
  • 题意:给定 n ( 1 ≤ n ≤ 10 ) n(1\le n\le 10) n(1≤n≤10) 个数组成的排列,其中前 m ( 0 ≤ m ≤ n ) m(0\le m\le n) m(0≤m≤n) 个数(即 1 1 1~ m m m) 在排列中位置随机,对于剩余 n − m n-m n−m 个数,设当前填充数字为 i ( n − m ≤ i ≤ n ) i(n-m\le i\le n) i(n−m≤i≤n):
    • 若第 i i i 位未被填充,则填充数字 i i i;
    • 否则, i i i 将被随机填充到先前未被填充的位上。
  • 关键词:搜索,思维(签到)

题解

下面给出两种解法:

DFS

注意到 n = 10 n=10 n=10,显而易见这是一道DFS板子题,不需要任何剪枝技巧,复杂度 O ( n ! ) O(n!) O(n!)。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m,cnt,yes;
vector<bool>v(11);
void dfs(int x){//x:当前处理数字
    if(x==n){//插满
        cnt++;
        if(!v[n]) yes++;
    }else if(x>m){//乱插结束
        if(!v[x]){
            v[x]=1;
            dfs(x+1);
            v[x]=0;
        }else{//乱插
            for(int i=1;i<=n;i++)
                if(!v[i]){
                    v[i]=1;
                    dfs(x+1);
                    v[i]=0;
                }
        }
    }else{
        for(int i=1;i<=n;i++)
	        if(!v[i]){
	              v[i]=1;
	              dfs(x+1);
	              v[i]=0;
          	}
    }
}
void solve(){
    cin>>n>>m;
    dfs(1);
    printf("%.10lf",yes/(double)cnt);
}
signed main(){
    // ios::sync_with_stdio(0),cin.tie(0);
    int t=1;
    while(t--) solve();
    return 0;
}

结论

手玩几个样例,不难发现:

若 n = m n=m n=m,则答案为 1 m \frac{1}{m} m1;否则答案为 1 m + 1 \frac{1} {m+1} m+11。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,k;
void solve(){
	if(n==k) printf("%.10lf",1/(double)k);
    else printf("%.10lf",1/(double)(k+1));
}
signed main(){
    scanf("%lld %lld",&n,&k);
	solve();
    return 0;
}
相关推荐
萘柰奈6 分钟前
LeetCode刷题记录----62.不同路径(Medium)
算法·leetcode·职场和发展
阳光明媚sunny12 分钟前
爬楼梯算法java实现
算法·动态规划
贝塔实验室39 分钟前
LDPC码的概念
科技·学习·程序人生·算法·学习方法·程序员创富·改行学it
weixin_307779131 小时前
矩形势阱(V(x) = -H for |x|≤L)的束缚态能级求解与宇称分类
算法
MMjeaty1 小时前
数据结构——栈和队列
数据结构·算法
机器学习之心6 小时前
多目标鲸鱼优化算法(NSWOA),含46种测试函数和9个评价指标,MATLAB实现
算法·matlab·多目标鲸鱼优化算法·46种测试函数·9个评价指标
max5006007 小时前
基于Meta Llama的二语习得学习者行为预测计算模型
人工智能·算法·机器学习·分类·数据挖掘·llama
王哥儿聊AI8 小时前
Lynx:新一代个性化视频生成模型,单图即可生成视频,重新定义身份一致性与视觉质量
人工智能·算法·安全·机器学习·音视频·软件工程
手握风云-10 小时前
优选算法的寻踪契合:字符串专题
算法
闭着眼睛学算法10 小时前
【华为OD机考正在更新】2025年双机位A卷真题【完全原创题解 | 详细考点分类 | 不断更新题目 | 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·javascript·c++·python·算法·华为od