当前位置: 首页 > news >正文

怎么做关于狗的网站做网站的软件dw

怎么做关于狗的网站,做网站的软件dw,北京seo技术交流,科技公司取名GitHub - jzplp/aoapc-UVA-Answer: 算法竞赛入门经典 例题和习题答案 刘汝佳 第二版 这道题需要: 1. 遍历二叉树的每种构成方式。我这里每次把当前所有结点列出,然后遍历选取两个组合构成一个新结点,原来的结点剔除,新结点加入。…

GitHub - jzplp/aoapc-UVA-Answer: 算法竞赛入门经典 例题和习题答案 刘汝佳 第二版

这道题需要:

1. 遍历二叉树的每种构成方式。我这里每次把当前所有结点列出,然后遍历选取两个组合构成一个新结点,原来的结点剔除,新结点加入。最后只剩一个结点时,就得到二叉树的一种情况。我这里相当于是从叶子结点向上遍历。由于数据量较少,所以我这里没有剪枝。

注意选取两个结点后也对应着两种,A放在左边B放在右边 和 B放在左边A放在右边。

2. 计算宽度时,左侧的宽度除了【左子树的宽度+绳子左侧的长度】之外,右子树的左子树也可能很宽,超过【左子树的宽度+绳子左侧的长度】。因此,要对【右子树的左子树-绳子右侧的长度】和【左子树的宽度+绳子左侧的长度】进行比较,看看谁更长。右侧同理。

#include<stdio.h>
#include<string.h>int stones[20];
int s;
double r;double maxWidth;struct Node {bool enable;int weight;double left, right;
};
Node arr[50];double max(double a, double b) {if(a > b) return a;return b;
}Node mergeNode(int i, int j) {Node no;no.enable = true;no.weight = arr[i].weight + arr[j].weight;double a = (double)arr[i].weight / no.weight;double b = (double)arr[j].weight / no.weight;no.left = max(b + arr[i].left, arr[j].left - a);no.right = max(a + arr[j].right, arr[i].right - b);return no;
}void getValue(int len) {int i;double value;for(i = 0; i < len; ++i) {if(arr[i].enable) {value = arr[i].left + arr[i].right;if(value <= r && value > maxWidth) {maxWidth = value;}return;}}
}void cal(int len, int enableLen) {int i ,j, k;if(enableLen == 1) {getValue(len);}for(i = 0; i < len; ++i) {if(!arr[i].enable) continue;for(j = i + 1; j < len; ++j) {if(!arr[j].enable) continue;// 二重循环找到一个组合 区分组合在左边和在右边的场景 --enableLen;arr[i].enable = false;arr[j].enable = false;arr[len] = mergeNode(i, j);cal(len+1, enableLen);arr[len] = mergeNode(j, i);cal(len+1, enableLen);++enableLen;arr[i].enable = true;arr[j].enable = true;}}
}int main() {int n, i;scanf("%d", &n);while(n--) {scanf("%lf %d", &r, &s);for(i = 0; i < s; ++i) scanf("%d", &stones[i]);if(s == 1) {printf("%.16lf\n", 0.0);continue;}maxWidth = -1;for(i = 0; i < s; ++i) {arr[i] = { true, stones[i], 0, 0 };}cal(s, s);if(maxWidth < 0)printf("-1\n");elseprintf("%.16lf\n", maxWidth);}return 0;
}

http://www.yayakq.cn/news/780395/

相关文章:

  • 两个网站合并建设实施方案雪锐琴网站建设
  • 网站搭建多少钱logo修改网站顶部广告
  • 网站建设沛宣有网站公司源码可以重建网站吗
  • 衡水做网站设计广东好的网络营销机构
  • 怎么开网站php网站开发哪个培训学校好
  • 网站制作的订单wordpress更新5.2
  • 如何用手机网站做淘宝客wordpress 时间选择器
  • 网站建设费用怎么入账黑龙江省建设厅官方网站
  • 佛山网站建设价格多少网站开发部门结构
  • 网站开发人员结构新手学做网站视频
  • 婚纱摄影网站html模板ups国际快递网站建设模块分析
  • 鄞州做网站锦州网站建设排行榜
  • 做黑网站赚钱吗云南南网站开发
  • 微网站是什么wordpress清楚缓存
  • 正规的徐州网站建设整站优化提升排名
  • 上海建设网站的网站设计店面装修
  • 什么叫网站智慧团建团员登录网站
  • 网站下面 备案免费小程序模板
  • 网站目录 index织梦怎么做网站地图
  • 建网站的公司排名做柜子设计的网站设计
  • 在百度做推广需要网站吗html5做静态网站
  • 天津网站设计成功柚米怎么做网站链接的快捷方式
  • 企业网站的建设目的是什么做平台的网站有哪些内容吗
  • 秦皇岛做网站公司排名网站营销外包公司
  • 网站备案指的是什么做外贸网站的公司
  • 怎么修改网站标题建设银行长春网站
  • 网站搭建中页面如何做网站服务器映射
  • 模板网站做外贸可以吗wordpress 显示图片啊
  • 做准考证的网站企业建设网站的过程
  • 帝国和织梦那个做企业网站好网站抽奖模块怎么做