PTA 小字辈(Java语言)

简介: PTA 小字辈(Java语言)

题目描述:

本题给定一个庞大家族的家谱,要请你给出最小一辈的名单。

输入格式:

输入在第一行给出家族人口总数 N(不超过 100 000 的正整数) —— 简单起见,我们把家族成员从 1 到 N 编号。随后第二行给出 N 个编号,其中第 i 个编号对应第 i 位成员的父/母。家谱中辈分最高的老祖宗对应的父/母编号为 -1。一行中的数字间以空格分隔。


输出格式:

首先输出最小的辈分(老祖宗的辈分为 1,以下逐级递增)。然后在第二行按递增顺序输出辈分最小的成员的编号。编号间以一个空格分隔,行首尾不得有多余空格。

输入样例:

9
2 6 5 5 -1 5 6 4 7

输出样例:

4
1 9

解题思路:

使用数组存,用递归思想找每个人的祖先并记录每一个人的辈分数。

注:使用c++语言就可以使用bfs很快就出来了,c++的vector存放数据很灵活。小字辈 bfs搜索

代码(超时)

优化前:

package text2;

import java.util.Scanner;

public class 小字辈 {

  public static void main(String[] args) {
    // TODO Auto-generated method stub
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();
    int a[] = new int[n+1];
    int b[]= new int[n+1];
    int max=1;
    for(int i=1;i<=n;i++) {
      a[i] = scanner.nextInt();
    }
    for(int i=1;i<=n;i++) {
//      int t=0;//临时记录辈分
      int x=i;
      b[i]=1;
      while(a[x]!=-1) {
        b[i]++;
        x=a[x];//往上找
      }
      if(b[i]>max) max = b[i];
    }
    System.out.println(max);
    int flag=0;
    for(int i=1;i<=n;i++) {
      if(b[i]==max) {
        if(flag==0) {
          System.out.print(i);
          flag++;
        }else {
          System.out.print(" "+i);
        }
      }
    }
  }

}

优化后:

package text2;

import java.util.ArrayList;
import java.util.Scanner;
import java.util.Vector;

public class 小字辈 {
  static int a[] = new int[100005];
  static int b[]= new int[100005];
  public static void main(String[] args) {
    // TODO Auto-generated method stub
//    Vector<Integer> a[][] = new Vector<Integer>;/
//    ArrayList<Integer> a = new ArrayList<Integer>();
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();
    int max=1;
    for(int i=1;i<=n;i++) {
      a[i] = scanner.nextInt();
    }
    for(int i=1;i<=n;i++) {
      int t=0;
      t=Find(i);
      if(t>max) max = t;
    }
    System.out.println(max);
    int flag=0;
    for(int i=1;i<=n;i++) {
      if(b[i]==max) {
        if(flag==0) {
          System.out.print(i);
          flag++;
        }else {
          System.out.print(" "+i);
        }
      }
    }
  }
  public static int Find(int x) {
    if(b[x]!=0) return b[x];
    else if(a[x]==-1) return b[x]=1;
    else {
      return b[x]=Find(a[x])+1;
    }
  }

}

相关文章
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
106 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
2月前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
5月前
|
Java Maven
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
该博客文章介绍了如何使用Java Swing中的JFrame创建一个窗体来收集用户输入的内容,并提供了详细的实现步骤和完整代码示例。
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
|
1天前
|
存储 监控 算法
探秘局域网桌面监控:深入剖析 Java 语言核心算法
在数字化办公时代,局域网桌面监控如同企业的“智慧鹰眼”,确保工作效率与数据安全。本文以Java为载体,揭示哈希表在监控中的关键应用。通过高效的数据结构和算法,哈希表能快速索引设备连接信息,大幅提升监控的时效性和响应速度。代码示例展示了如何用Java实现设备网络连接监控,结合未来技术如AI、大数据,展望更智能的监控体系,助力企业在数字化浪潮中稳健前行。
|
2月前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
59 4
|
3月前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
70 3
|
3月前
|
移动开发 Java 大数据
深入探索Java语言的核心优势与现代应用实践
【10月更文挑战第10天】深入探索Java语言的核心优势与现代应用实践
117 4
|
3月前
|
存储 Java 数据安全/隐私保护
Java中的域,什么是域?计算机语言中的域是什么?(有代码实例)
文章解释了Java中域的概念,包括实例域、静态域、常量域和局部域,以及它们的特点和使用场景。
96 2
|
3月前
|
Java 数据安全/隐私保护 C++
Java语言关键字
Java语言关键字
42 2
|
3月前
|
分布式计算 安全 Java
Java语言的特点?
Java语言的特点?
下一篇
开通oss服务