2020.9.23 金山云后台开发岗笔试

38 篇文章 0 订阅
10 篇文章 1 订阅

1.子树的权重 结束写的 DFS

时间限制: 3000MS
内存限制: 589824KB

题目描述:

首先按照从上到下、从左到右的顺序输入一棵满二叉树中每一个结点对应的权重,例如输入1、1、2表示二叉树的根结点的权重为1,它的左、右两个子节点的权重分别为1和2。
然后判断该满二叉树中是否存在这样的非叶子结点:它的左子树上所有结点的权重之和等于右子树上所有结点的权重之和。
现在给你一棵满二叉树的所有结点的权重,请编写一个程序,寻找是否存在满足要求的非叶子结点,如果存在输出“Yes”,否则输出“No”。

输入描述

多组输入。
第1行输入一个正整数T表示测试数据的数量。(T<=100)
接下来T行对应T组输入,每组输入数据占一行,该行包含n个正整数(n满足2^k-1),两两之间用空格隔开,1<n<=1000。

输出描述
对于每组输入数据,如果能够找到满足要求的非叶子结点(左子树上所有结点的权重之和等于右子树上所有结点的权重之和),输出“Yes”,否则输出“No”。

样例输入
3
1 2 2 1 2 1 2
1 2 2 1 3 2 2
1 2 2 1 2 1 3
样例输出
Yes
Yes
No

import java.util.Scanner;
/*
3
1 2 2 1 2 1 2
1 2 2 1 3 2 2
1 2 2 1 2 1 3
 */
public class Main {

    public static void main(String[] args) {
        //处理输入
        Scanner sc = new Scanner(System.in);
        int T = sc.nextInt();
        sc.nextLine();

        for(int t  = 0; t < T; t++){
            String[] strs = sc.nextLine().split(" ");
            int n = strs.length;
            int[] nums = new int[n+1];
            for(int i = 1; i < n+1; i++){
                nums[i] = Integer.parseInt(strs[i-1]);
            }

            //
            boolean[] flag  = new boolean[1];
            func(nums, 1, flag);
            System.out.println(flag[0] == true ? "YES" : "NO"  );
        }
    }


    public static int func(int[] nums, int index, boolean[] flag){
        if(index >= nums.length) return 0;

        int leftSum = 0;
        if(index*2 < nums.length){
            leftSum = func(nums, index*2, flag);
        }

        int rightSum = 0;
        if(index*2+1 < nums.length){
            rightSum = func(nums,index*2+1, flag);
        }

        //比较左节点和右节点
        if(leftSum == rightSum && leftSum != 0){
            flag[0] = true;
        }

        //System.out.println(leftSum + " " + rightSum + " " + (leftSum + rightSum + nums[index]) + " " + flag[0]);
        return leftSum + rightSum + nums[index];
    }
}




2. 5的个数 AC

时间限制: 3000MS
内存限制: 589824KB

题目描述:

小明最喜欢的数字是5。他在班上的学号是5号,也是学校足球队的5号队员。
现在小明希望你帮他编写一个程序,输入一个正整数n,输出从数字1到数字n中,一共出现了多少个5。

输入描述
单组输入。
输入一个正整数n,1<n<=100000。
输出描述
输出一个整数,即1到n的数字中5出现的个数。
样例输入
50
样例输出
6

import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        int n = sc.nextInt();
        int res = 0;
        for(int i = 1; i <= n; i++){
            int num = i;
            while(num != 0){
                if(num % 10 == 5){
                    res++;
                }
                num/=10;
            }
        }
        System.out.println(res);
    }
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安安csdn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值