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

网站开发dreamweaver西安seo黑

网站开发dreamweaver,西安seo黑,ecshop网站建设方案书,成都市建设招标网站题目描述 设有一棵二叉树,如图: 其中,圈中的数字表示结点中居民的人口。圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接点之间的距…

题目描述

设有一棵二叉树,如图:

其中,圈中的数字表示结点中居民的人口。圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接点之间的距离为 11。如上图中,若医院建在 11 处,则距离和 =4+12+2×20+2×40=136;若医院建在 3 处,则距离和=4×2+13+20+40=81。

输入格式

第一行一个整数 n,表示树的结点数。

接下来的 n 行每行描述了一个结点的状况,包含三个整数 w,u,v,其中 w 为居民人口数,u 为左链接(为 0 表示无链接),v 为右链接(为0 表示无链接)。

输出格式

一个整数,表示最小距离和。

输入输出样例

输入 #1

5						
13 2 3
4 0 0
12 4 5
20 0 0
40 0 0

输出 #1

81

说明/提示

数据规模与约定

对于 100%的数据,保证 1≤n≤100,0≤u,v≤n,1≤w≤10^5。

 解题思路

本题求距离和最短,可以用广搜,首先一重循环遍历以不同点为终点,再嵌套一重循环,遍历每一个起点,求所以起点到终点的距离之和,每次更新最小值,我们知道二叉树的每个结点有三个去向父节点,左孩子,右孩子,题目已经要求输入每个点的左右孩子,所以只要求出每个点的父节点就行了,具体操作看代码。

#include<stdio.h>
struct nb {//2叉树结点int data;//每个结点的人数int f;//父节点int lchild, rchild;//左右孩子
}a[110];
struct nm {//列队用于广搜int x;//编号int s;//步数
}b[100100];
int n, book[110];//book数组用于标记 
void dfs(int x,int y)//求父节点 x为编号,y为父节点
{if (x == 0)//没有孩子,结束递归return;a[x].f = y;dfs(a[x].lchild, x);//往左孩子走dfs(a[x].rchild, x);//往右孩子走return;
}
int main()
{int i, j, min = 1e9;scanf("%d", &n);for(i=1;i<=n;i++)//scanf("%d %d %d", &a[i].data, &a[i].lchild, &a[i].rchild);dfs(1, 0);//从根结点开始for (i = 1; i <= n; i++)//分别以每一个点为终点{int sum = 0;for (j = 1; j <= n; j++)//遍历每一个起点{if (i == j)//起点终点重合直接跳过continue;for (int q = 1; q <= n; q++)//初始化标记数组book[q] = 0;//列队插入起点int hard = 1, tail = 1, flag = 0;b[tail].x = j; b[tail].s = 0;book[j] = 1; tail++;while (hard < tail){for (int q = 1; q <= 3; q++)//往三个方向走,父节点,左孩子,右孩子{int t;if (q == 1)t = a[b[hard].x].f;//往父节点走else if (q == 2)t = a[b[hard].x].lchild;//往左孩子elset = a[b[hard].x].rchild;//往右孩子if (t == 0)//没有子节点或父节点continue;if (book[t] == 0)//如果第一次来这个点{//入队操作b[tail].x = t; book[t] = 1;b[tail].s = b[hard].s + 1; tail++;if (t == i)//如果找到终点{flag = 1;break;}}}if (flag == 1){sum += a[j].data * b[tail - 1].s;//计算路程break;}hard++;}}if (min > sum)//更新最小值min = sum;}printf("%d", min);//打印结果return 0;
}

http://www.dinnco.com/news/3784.html

相关文章:

  • 网站模板css网络营销企业案例分析
  • 工商银行网页版官网郑州百度关键词seo
  • wordpress 海淘主题下载seo基础理论
  • 合肥哪家公司做网站百度网址大全 旧版本
  • diy电子商城网站贵阳关键词优化平台
  • 手机购物app排行榜前十名中国seo谁最厉害
  • 医院做网站需要备案吗长春百度推广排名优化
  • 免签约收款WordPress百度首页优化排名
  • 毕设做网站工作量够吗南宁最新消息今天
  • 网站建设运营预算aso优化吧
  • 网站建设的方法武汉seo公司排名
  • oss做网站seo优质友链购买
  • 易支付做网站接口怎么赚钱软文推广文章案例
  • 做网站下载那个数据库好成都新一轮疫情
  • 长沙专业的建站按效果付费人民日报最新新闻
  • 关注江苏建设厅网站厦门网站的关键词自动排名
  • 怎样把建好的网站上传到互联网seo优化网站推广全域营销获客公司
  • 自己做的网站如何兼容手机百度搜索
  • 湛江怎么做网站关键词优化海南百度推广公司
  • 选择常州网站建设公司上饶seo博客
  • 六安网站建设收录排名好的发帖网站
  • html网页制作实例代码大地seo视频
  • wordpress星评分常州seo外包公司
  • 做生鲜管理系统的网站在百度上怎么注册网站
  • 佛山网站建设流程地产渠道12种拓客方式
  • 国税网站页面申报撤销怎么做百度推广渠道
  • 淘客怎么做网站如何查询百度搜索关键词排名
  • 深圳微商城网站设计制作蜜雪冰城推广软文
  • 优购物官方网站今日直播喜来健重庆seo的薪酬水平
  • 扬州市工程信息网seo自学教程seo免费教程