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

想给公司注册一个网站建设银行租房平台网站

想给公司注册一个网站,建设银行租房平台网站,如何免费自做企业网站,wordpress页面关键词和描述文章目录 1. 题目描述2. 我的尝试 1. 题目描述 给定一颗二叉树,树的每个节点的值为一个正整数。如果从根节点到节点 N 的路径上不存在比节点 N 的值大的节点,那么节点 N 被认为是树上的关键节点。求树上所有的关键节点的个数。请写出程序,并…

文章目录

  • 1. 题目描述
  • 2. 我的尝试

1. 题目描述

给定一颗二叉树,树的每个节点的值为一个正整数。如果从根节点到节点 N 的路径上不存在比节点 N 的值大的节点,那么节点 N 被认为是树上的关键节点。求树上所有的关键节点的个数。请写出程序,并解释解题思路。
在这里插入图片描述

输入:3, 1, 4, 3, null, 1, 5
输出:4(图中蓝色节点是关键节点)

2. 我的尝试

这道题麻烦的地方在于输入与建树。由题意可知,输入数据是以完全二叉树形式进行输入的,因此可以考虑直接用数组来存储树,然后再遍历每一个节点并判断其是否为关键节点。

数据的输入是以空格作为分隔符的,因此不适宜直接用 cin进行读入。可以用 getline 函数读入整行,再对读入的字符串遍历进行处理。

#include <bits/stdc++.h>using namespace std;int main() {string str;    // 存储输入的字符串int val = 0;   // 用于计算当前输入节点的值vector<int> tree;int cnt = 0;getline(cin, str);int n = str.size();// 建树for (int i = 0; i < n; i ++) {auto c = str[i];if ('0' <= c && c <= '9') {val = val * 10 + c - '0';} else if (val) {tree.push_back(val);val = 0;} else if (c == 'n') {tree.push_back(-1);}}tree.push_back(val);n = tree.size();// 对除根节点外所有节点遍历,将其与各祖先节点比较,判断是否为关键节点for (int i = 0; i < n && tree[i] != -1; i ++) {int val = tree[i]; bool flag = true;for (int p = (i - 1) / 2; p >= 0; p = (p - 1) / 2) {if (tree[p] > val) flag = false;if (p == 0) break;}if (flag) cnt ++;}// 根节点一定为关键节点,直接加1cnt ++;cout << cnt;
}
http://www.yayakq.cn/news/43429/

相关文章:

  • 外贸网站服务器选择南京制作手机网站
  • 化妆品网站下载linux 什么做网站好
  • 网站研发进度表下载电话卡代理平台
  • 公司网站改版设计网站托管服务商
  • 小公司做网站需要注意什么外贸付款方式
  • 十八把网站做扇子个人中心页面模板
  • 网站需求怎么写百度识图网页版 在线
  • 酒店类网站建设方案书用电信固定IP做网站
  • 网站风格要求做网站的广告图片
  • 哈尔滨做网站的oeminc创建网站大约多少钱2018
  • 网站开发哪里安全怎么在网站上做旅游推广
  • 成都便宜网站建设上海idc机房托管
  • 做网站 图片需要多大的上海模板网站
  • 如何快速建立网站装修房子的效果图
  • 通过招聘网站如何做背景调查wordpress 点击量
  • 如何让网站火起来如何帮人做网站
  • 青岛慧思网站建设网站动态图怎么做
  • 怎么样自己做最简单的网站淮南直聘网
  • 给上市公司做网站有什么用厦门做网站 厦门专业做网站的公司 我想做网站
  • 福州网站建设发布卡盟网站建设
  • 网站建设找工作高端网站案例网站建设
  • 安微省住房和城乡建设厅网站wordpress链接英文
  • 企业网站手机版源码下载温州的高端设计公司
  • 郴州做网站ku0735做网站需要什么人
  • 做网站行业统称叫什么行业网站文章的作用
  • 网站登录注册页面模板企业软文营销
  • 影视广告制作公司seo搜索引擎优化报价
  • 网站个人备案wordpress读取菜单
  • 创新的南昌网站设计网页设计的主题说明
  • 便宜建站建设网站需要做的工作