码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • P1433 吃奶酪


    1. #include <iostream>
    2. #include <cmath>
    3. using namespace std;
    4. #define M 15
    5. #define S(n) ((n) * (n))
    6. double indx[M + 5], indy[M + 5], ans = 0, sum = 0;//坐标数组,从下标为1开始记录
    7. int n, vis[M + 5] = { 0 };//vis数组,选过的数字标记为1,没选过的数字标记为0
    8. double dis(int i, int j) {
    9. return sqrt(S(indx[i] - indx[j]) + S(indy[i] - indy[j]));
    10. }
    11. //c表示当前已经选了c个数字
    12. //k表示最后一次选的是第k个点
    13. void fun(int c, int k) {
    14. if (c == n) {
    15. if (!ans || ans > sum) ans = sum;
    16. return;
    17. }
    18. for (int i = 1; i <= n; i++) {
    19. if (vis[i]) continue;
    20. vis[i] = 1;
    21. sum += dis(i, k);
    22. fun(c + 1, i);
    23. vis[i] = 0;
    24. sum -= dis(i, k);
    25. }
    26. return;
    27. }
    28. int main() {
    29. cin >> n;
    30. for (int i = 1; i <= n; i++) {
    31. cin >> indx[i] >> indy[i];
    32. }
    33. fun(0, 0);
    34. printf("%.2lf", ans);
    35. return 0;
    36. }

     8组超时,优化

    1. #include <iostream>
    2. #include <cmath>
    3. using namespace std;
    4. #define M 15
    5. #define S(n) ((n) * (n))
    6. double indx[M + 5], indy[M + 5], dp[70000][M + 5] = { 0 }, ans = 0; //坐标数组,从下标为1开始记录
    7. //dp[i][j]:选择内容为i,最后一次选择的数字为j,的路径总长度
    8. int n, vis[M + 5] = { 0 }; //vis数组,选过的数字标记为1,没选过的数字标记为0
    9. double dis(int i, int j) { //返回第i个点到第j个点的距离
    10. return sqrt(S(indx[i] - indx[j]) + S(indy[i] - indy[j]));
    11. }
    12. //c表示当前已经选了c个数字
    13. //k表示最后一次选的是第k个点
    14. //m的二进制代表选择的内容
    15. //sum表示这c个数字当前方案的路径总长度
    16. void fun(int c, int k, int m, double sum) {
    17. if (c == n) {
    18. ans = sum;
    19. return;
    20. }
    21. dp[m][k] = sum; //到达一个新的节点,第一步就更新以m为内容,k为末端的路径长度
    22. for (int i = 1; i <= n; i++) {
    23. if (vis[i]) continue;
    24. int a = m + pow(2, i); //m如果自增,递归回来又要减,太麻烦,定义一个a
    25. double d = dis(i, k); //后面最多用到三次,算出来方便用
    26. //以a为内容、i为路径已经被遍历过了,且之前的值小于等于这次遍历过去的值,那就不遍历过去了
    27. if (dp[a][i] != 0 && dp[a][i] <= sum + d) continue;
    28. //ans不为0且这次遍历过去sum超过ans,那就没必要过去了
    29. if (ans && ans <= sum + d) continue;
    30. vis[i] = 1;
    31. fun(c + 1, i, a, sum + d);
    32. vis[i] = 0;
    33. }
    34. return;
    35. }
    36. int main() {
    37. cin >> n;
    38. for (int i = 1; i <= n; i++) {
    39. cin >> indx[i] >> indy[i];
    40. }
    41. fun(0, 0, 0, 0);
    42. printf("%.2lf", ans);
    43. return 0;
    44. }

  • 相关阅读:
    Ansible FIle模块,使用Ansible File模块进行文件管理
    LeetCode 算法:无重复字符的最长子串c++
    吉尔吉斯斯坦公司如何注册 吉尔吉斯斯坦公司年审 吉尔吉斯斯坦公司开户
    凉鞋的 Godot 笔记 102. 场景与节点的增删改查
    Shell脚本编写教程【十】——Shell 输入/输出重定向
    GO语言学习笔记(一) 概述
    阿里大手子评:入门到大成!GitHub新上线并发编程深度解析实战PDF
    评估指标Pre\Rec\F1\AUC
    【经验贴-leetcode报错没头绪时的小妙招(非会员)】
    江门晚造粮食(水稻)扩种1万亩 国稻种芯:“以晚补早”夺丰收
  • 原文地址:https://blog.csdn.net/Mz_yuner/article/details/133834921
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号