1038专题

PAT 甲级 1038 Recover the Smallest Number 两种思路

这道题的大致思路是每次把能够让拼接后的数字最小的串放在前面,怎么来比较哪个放在前面最小呢?考虑下面两种情况 情况1:321 32 324 情况2:131 13 134 显然应该把第一位最小的放在最前面,第一位相同比较第二位,如果所有位都相同呢?比如上面32和13的情况?可以循环进行比较。比如判断321和32谁放在前面的时候,比较3和3,2和2,3和1得到结果321更小,所以321放在前面。这个循环

【PAT】【Advanced Level】1038. Recover the Smallest Number (30)

1038. Recover the Smallest Number (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Given a collection of number segments, you are supposed to r

hdu 1038(ACM steps 1.2.1)Biker's Trip Odometer

题目描述: Biker's Trip Odometer Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 2848 Accepted Submission(s): 1263  Problem Description Most bicycle

LightOJ 1038 - Race to 1 Again(dp)

题目链接:LightOJ 1038 - Race to 1 Again 代码 #include <cstdio>#include <cstring>#include <vector>#include <algorithm>using namespace std;const int maxn = 1e5;double dp[maxn + 5];vector<int> G[maxn +

PAT-乙级 1038 统计同成绩学生(C语言)

首先给出自己做法,也是大多数的做法,但是最后一个测试点死活过不去,考虑到是两个for循环占用了绝大多数时间。后来再看题目时,发现分数是百分制,最后解决 #include<stdio.h>#include<stdlib.h>int main() {int studentNumber;scanf("%d", &studentNumber);int* studentPointer = calloc

1038: 顺序表中重复数据的删除

解法: #include<iostream>#include<vector>#include<algorithm>using namespace std;int main() {int n, k;cin >> n;vector<int> arr(n);for (auto& x : arr) cin >> x;cin >> k;int sum = 0;for (auto x : arr

【ZZULIOJ】1038: 绝对值最大(Java)

目录 题目描述 输入 输出 样例输入 Copy 样例输出 Copy code 题目描述 输入3个整数,输出绝对值最大的那个数。 输入 输入包含3个int范围内的整数,用空格隔开。 输出 输出三个数中绝对值最大的数,单独占一行。若绝对值最大的数不唯一,则输出最先出现的那个。例如,若输入为1 -3 3,则输出为-3;若输入为1 3 -3则输出为3。 样例输入 Copy

1038 Recover the Smallest Number

idea 给出若干个可能含有前导0的数字串,将其进行拼接使其组成的数最小。 拼接串,想到借助string。 找最小,样例中的32,321, 3214尤为具备代表性,让字典序小的数尽可能靠前,联想到string的比较规则也是字典序 ==>判断string字符串s1和s2的前后,需要比较的是它们拼接后形成的数值字典序最小 ==>转化为比较s1+s2和s2+s1的字典序,则直接进行比较即可(stl

一本通1038:苹果和虫子

1038:苹果和虫子 时间限制: 1000 ms         内存限制: 65536 KB 提交数: 113386     通过数: 32405 【题目描述】 你买了一箱n个苹果,很不幸的是买完时箱子里混进了一条虫子。虫子每x小时能吃掉一个苹果,假设虫子在吃完一个苹果之前不会吃另一个,那么经过y小时你还有多少个完整的苹果? 【输入】 输入仅一行,包括n,x和y(均为整数)。

poj 1038

http://poj.org/problem?id=1038 这题我找Wrong找到想吐了。。。。本来就是看别人的代码,别人的思路写的,感觉都一模一样了,但还是Wrong。我就从别人正确的代码,一个函数一个函数的换成我的函数,wocao,怎么全部搬过来都还是AC了。。。。。。最上面怎么会有问题???难道头文件会Wrong??? 哇~这要是真的的话,那我就发现了什么不得了的事了(〃’▽’〃)

1038. 统计同成绩学生

一、题目 本题要求读入N名学生的成绩,将获得某一给定分数的学生人数输出。 输入格式: 输入在第1行给出不超过105的正整数N,即学生总人数。随后1行给出N名学生的百分制整数成绩,中间以空格分隔。最后1行给出要查询的分数个数K(不超过N的正整数),随后是K个分数,中间以空格分隔。 输出格式: 在一行中按查询顺序给出得分等于指定分数的学生人数,中间以空格分隔,但行末不得有多余空格。 输入样

B (1038) : DS哈希查找—二次探测再散列

文章目录 一、题目描述二、输入与输出1.输入2.输出 三、参考代码 一、题目描述 定义哈希函数为H(key) = key%11。输入表长(大于、等于11),输入关键字集合,用二次探测再散列构建哈希表,并查找给定关键字。 二、输入与输出 1.输入 311 818 25 11 19 20 3 10 13717262025241111 69 2

1038. 从二叉搜索树到更大和树 --力扣 --JAVA

题目 给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提醒一下, 二叉搜索树 满足下列约束条件: 节点的左子树仅包含键 小于 节点键的节点。节点的右子树仅包含键 大于 节点键的节点。左右子树也必须是二叉搜索树。 解题思路 由题意可知需要先获取右子树的值累加再赋值给当前节点,因此使用递归;创建全局变量用来存储累加后的值;右子

​LeetCode解法汇总1038. 从二叉搜索树到更大和树

目录链接: 力扣编程题-解法汇总_分享+记录-CSDN博客 GitHub同步刷题项目: https://github.com/September26/java-algorithms 原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 描述: 给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提

leetcode做题笔记1038. 从二叉搜索树到更大和树

给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提醒一下, 二叉搜索树 满足下列约束条件: 节点的左子树仅包含键 小于 节点键的节点。节点的右子树仅包含键 大于 节点键的节点。左右子树也必须是二叉搜索树。   示例 1: 输入:[4,1,6,0,2,5,7,null,null,null,3,null,null,nul

力扣(LeetCode)1038. 从二叉搜索树到更大和树(C++)

先序遍历 根据题意,给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。模拟二叉搜索树替换到更大和数的过程, 请了解性质:二叉搜索树的先序遍历,是一个正序数组 直观思路,先序遍历(左根右)得到正序数组,再反向先序遍历(右根左)二叉搜索树,根据正序数组倒着累加在树上。 请思考:反向先序遍历(右根左)二叉搜索树的结果,正是二叉搜索树的逆序

LeetCode 1038. 从二叉搜索树到更大和树:(反)中序遍历

【LetMeFly】1038.从二叉搜索树到更大和树:(反)中序遍历 力扣题目链接:https://leetcode.cn/problems/binary-search-tree-to-greater-sum-tree/ 给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提醒一下, 二叉搜索树 满足下列约束条件: 节点的左子树仅

【算法思考记录】力扣1038. 从二叉搜索树到更大和树【C++,递归,中序遍历】

力扣1038. 从二叉搜索树到更大和树 从二叉搜索树到更大和树:理解中序位置的递归解法 问题概述 二叉搜索树(BST)是一种特殊的二叉树,它的每个节点都满足以下条件: 左子树的所有节点值小于当前节点值。右子树的所有节点值大于当前节点值。 本文探讨的问题是:如何将BST的每个节点的值替换为树中大于或等于该节点值的所有节点值之和。 示例 例如,输入的BST为 [4,1,6,0,2,

二叉树遍历 LeetCode 1038. 从二叉搜索树到更大和树

1038. 从二叉搜索树到更大和树 给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 从图中可以看出,每个节点是BST右中左遍历时,遍历到的节点的值加上之前所有节点的值。 在遍历时可以使用一个全局变量,表示之前所有节点的值,并维护这个变量。 class Solution {public:int cur;void dfs(T

【每日一题】1038. 从二叉搜索树到更大和树-2023.12.4

题目: 1038. 从二叉搜索树到更大和树 给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提醒一下, 二叉搜索树 满足下列约束条件: 节点的左子树仅包含键 小于 节点键的节点。节点的右子树仅包含键 大于 节点键的节点。左右子树也必须是二叉搜索树。 示例 1: 输入:[4,1,6,0,2,5,7,

1038. 从二叉搜索树到更大和树

​题目来源:         leetcode题目,网址:1038. 从二叉搜索树到更大和树 - 力扣(LeetCode) 解题思路:        从最大节点开始求和并修改响应节点即可。 解题代码: /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;*

力扣1038. 从二叉搜索树到更大和树(java,树的中序遍历解法)

Problem: 1038. 从二叉搜索树到更大和树 文章目录 题目描述思路解题方法复杂度Code 题目描述 给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提醒一下, 二叉搜索树 满足下列约束条件: 节点的左子树仅包含键 小于 节点键的节点。 节点的右子树仅包含键 大于 节点键的节点。 左右子树也必须是

poj 1038 - Bugs Integrated, Inc.(状态压缩dp)

题意:     从n*m的矩阵中裁剪2*3的小矩形,其中有些方块不能用【题目以坐标方式给出】,问最多可以得到多少小矩形。 思路:       要知道能否以当前行作为小矩形的最后一行,需要知道以上三行的状态信息,因为我们切割的时候可以横着也可以竖着。     同时由于一旦 方格 (x-1, y)被黑色记号或其他芯片占据,则方格(x-2,y)即便空闲对第 x行芯片的放置也毫无意义,所以每个节点

leetcode 1038. Binary Search Tree to Greater Sum Tree

leetcode 1038. Binary Search Tree to Greater Sum Tree 题意:看题目。 代码: /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode(i

Leetcode 1038. 把二叉搜索树转换为累加树

题目描述 给出二叉 搜索 树的根节点,该树的节点值各不相同,请你将其转换为累加树(Greater Sum Tree),使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。 提醒一下,二叉搜索树满足下列约束条件: 节点的左子树仅包含键 小于 节点键的节点。 节点的右子树仅包含键 大于 节点键的节点。 左右子树也必须是二叉搜索树。 来源:力扣(LeetCode)