リンクリストの2進数をC++の整数に変換する
単一リンクリストへの参照ノードである「ヘッド」が1つあるとします。リンクリストに存在する各ノードの値は0または1です。このリンクリストには、数値のバイナリ表現が格納されます。リンクリストにある数値の10進数値を返す必要があります。したがって、リストが[1,0,1,1,0,1]
のような場合これを解決するには、次の手順に従います-
-
x:=リスト要素を配列に変換する
-
次に、リストを逆にしますx
-
ans:=0、およびtemp:=1
-
範囲i:=0のiの場合、x –1のサイズまで
-
ans:=ans + x [i] * temp
-
temp:=temp * 2
-
-
ansを返す
例(C ++)
理解を深めるために、次の実装を見てみましょう-
#include <bits/stdc++.h> using namespace std; class ListNode{ public: int val; ListNode *next; ListNode(int data){ val = data; next = NULL; } }; ListNode *make_list(vector<int> v){ ListNode *head = new ListNode(v[0]); for(int i = 1; i<v.size(); i++){ ListNode *ptr = head; while(ptr->next != NULL){ ptr = ptr->next; } ptr->next = new ListNode(v[i]); } return head; } class Solution { public: vector <int> getVector(ListNode* node){ vector <int> result; while(node){ result.push_back(node->val); node = node->next; } return result; } int getDecimalValue(ListNode* head) { vector <int> x = getVector(head); reverse(x.begin(), x.end()); int ans = 0; int temp = 1; for(int i = 0; i < x.size(); i++){ ans += x[i] * temp; temp *= 2; } return ans; } }; main(){ Solution ob; vector<int> v = {1,0,1,1,0,1}; ListNode *head = make_list(v); cout << ob.getDecimalValue(head); }
入力
[1,0,1,1,0,1]
出力
45
-
C++のバイナリツリーのリンクリスト
二分木ルートと、最初のノードとしてヘッドを持つリンクリストがあるとします。リンクリスト内の先頭から始まるすべての要素が、バイナリツリーで接続されている下向きのパスに対応している場合はTrueを返す必要があり、そうでない場合はFalseを返す必要があります。したがって、ツリーが次のような場合- リンクリストが[1,4,2,6]の場合、出力はtrueになります。 これを解決するには、次の手順に従います- マップdpを定義する ソルブ()と呼ばれるメソッドを定義します。これはヘッド、ルート、フラグを取ります ヘッドがnullの場合はtrueを返し、ルートがnullの場合は
-
バイナリツリーをC++のリンクリストにフラット化する
二分木があるとしましょう。リンクリストにフラット化する必要があります。したがって、ツリーが次のような場合- 出力ツリーは-になります これを解決するには、次の手順に従います- ser prev:=null rootを入力として受け取る再帰関数solve()を定義します。 ルートがnullの場合は、を返します。 解決(ルートの権利) 解決(ルートの左側) ルートの右側:=prev、ルートの左側:=null 前:=ルート 理解を深めるために、次の実装を見てみましょう- 例 #include <bits/stdc+