Re: [閒聊] 每日leetcode

作者: oin1104 (是oin的說)   2024-07-16 12:46:51
※ 引述 《Rushia (早瀬ユウカの体操服)》 之銘言:
:  
: https://leetcode.com/problems/step-by-step-directions-from-a-binary-tree-node-
: to-another/
: 2096. Step-By-Step Directions From a Binary Tree Node to Another
: 給你一個二元樹的根節點以及startValue、destValue,你可以往上、往右、往左移動,

: 出startValue到destValue的最短路徑要怎麼走。
:  
思路 :
偷看到刪除共同路徑
就知道什麼意思了
就是有點像前綴合的感覺
把走過的一樣的路刪掉
那些都是多餘的
這樣就可以找到最開始不一樣的地方
那就是最短的路
我要去吃早餐了
```cpp
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), ri
ght(right) {}
* };
*/
class Solution {
public:
string startpath;
string destpath;
int startValuea;
string path;
void find(TreeNode* root , int target)
{
if(root == NULL)return ;
if(target == root->val)
{
if(target == startValuea)
{
startpath = path;
}
else
{
destpath = path;
}
return ;
}
path+="L";
find(root->left,target);
path.pop_back();
path+="R";
find(root->right,target);
path.pop_back();
}
string getDirections(TreeNode* root, int startValue, int destValue)
{
startValuea = startValue;
find(root,startValue);
find(root,destValue);
int sp = 0;
int dp = 0;
while(dp<destpath.size() && sp<startpath.size() && startpath[sp] == dest
path[dp])
{
sp++;
dp++;
}
string res(startpath.size()-sp,'U');
res += destpath.substr(dp,destpath.size()-dp);
return res;
}
};
```
作者: JIWP (JIWP)   2024-07-16 12:50:00
我好崇拜你
作者: mrsonic (typeB)   2024-07-16 12:51:00
你有什麼用
作者: Furina (芙寧娜)   2024-07-16 12:54:00
我好崇拜你

Links booklink

Contact Us: admin [ a t ] ucptt.com