PTA 7-9(树) 目录树(30 分) 30分代码 建树+输出

博客内容讲述了如何处理PTA中的树形问题,通过建立树的结构体节点,并利用vector存储子树节点来构建目录树。重点在于理解输入格式,按照题目给定的顺序输出目录和文件。提供了AC代码用于解决这个问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

赤裸裸的建树然后输出

需要注意的是 输出的顺序:

先输出目录,在输出文件,,但这个划分使他题目给定的,而不是后面没有子文件来判定目录

这样在输入的时候处理好就是了


方法就是 利用结构体node 做一棵树的根结点,,vec 里面存他的子树结点(也就是另一棵树的根结点)

(注: 博客作为交流使用,请勿抄袭应付作业)


下面是 AC 代码:


#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 500+7, INF = 0x7f7f7f7f;

int n, cur;
string s, t, a[maxn];
int b[maxn];

struct node {
    string name;
    int f;
    vector<node> vec;
    node() {}
    node(string s, int f_) { name = s; f = f_; /*cout << " 2333 " << endl;*/ }
    bool operator < (const node n2) const {
        if(f == n2.f) return name < n2.name;
        return f > n2.f;
    }
}root;


void add(node& no, int pos, int cnt) {
    if(pos == cnt) return;
    int i
### PTA 7-46 题目 Java 实现解决方案 对于PTA平台上的题目,采用高效的输入输出方式能够显著提升程序性能。针对Java语言而言,使用`BufferedReader`进行字符流输入可以有效减少时间消耗,防止因输入操作而导致的超时问题[^1]。 下面是一个基于此原则设计的PTA 7-46题目的Java实现案例: 假设该题目涉及处理一系列整数并执行特定逻辑运算,则可以通过如下方式进行编码: ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String line; while ((line = br.readLine()) != null && !line.isEmpty()){ // 对读取到的数据做进一步解析和处理 // 示例:将字符串形式的一行数字转换成int数组 int[] nums = java.util.Arrays.stream(line.split(" ")) .mapToInt(Integer::parseInt) .toArray(); // 执行具体的业务逻辑... // 输出结果 System.out.println(/* 计算后的结果 */); } } } ``` 为了确保解答的质量与准确性,在编写代码过程中需要注意以下几个要点: - **深入理解数据结构**:合理选用合适的数据结构来存储中间计算结果或辅助变量,比如本例中的`Map`或其他集合类容器[^3]。 - **考虑边界条件**:务必考虑到各种极限情况下的行为表现,如空输入、最大/最小值等情况,以此保障算法鲁棒性。 - **优化算法效率**:不断探索更加高效的方法论去简化现有流程,力求达到最优解法;同时也要兼顾可读性和易维护性的平衡. 通过上述措施的应用,不仅有助于提高代码质量,还能增强应对复杂场景的能力。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值