まえがき
スタックとは何ですか? 先入れ後出しのデータ構造 (First In Last Out)、制限された操作を備えた線形テーブルとして理解できます...
C 実装
「C 言語での void ポインターと関数ポインターの使用」の助けを借りて、チェーンされたユニバーサル スタックを実装できます:
/* stack.h */ #ifndef _STACK_H_ #define _STACK_H_ typedef struct stackNode { void *value; struct stackNode *next; } stackNode; typedef struct stack { stackNode *top; void (*free)(void *ptr); unsigned long size; } stack; /* Functions implemented as macros */ #define stackTop(s) ((s)->top) #define stackSize(s) ((s)->size) #define stackSetFreeMethod(s, m) ((s)->free = (m)) #define stackGetFreeMethod(s) ((s)->free) stack *stackCreate(void); stack *stackPush(stack *stack, void *value); stackNode *stackPop(stack *stack); void stackClear(stack *stack); #endif /* _STACK_H_ */ /* stack.c */ #include <stdlib.h> #include "stack.h" stack *stackCreate(void) { struct stack *stack; if ((stack = (struct stack *)malloc(sizeof(struct stack))) == NULL) return NULL; stack->top = NULL; stack->free = NULL; stack->size = 0; return stack; } stack *stackPush(stack *stack, void *value) { stackNode *node; if ((node = (stackNode *)malloc(sizeof(stackNode))) == NULL) return NULL; node->value = value; node->next = (stack->size == 0) ? NULL : stack->top; stack->top = node; stack->size++; return stack; } stackNode *stackPop(stack *stack) { stackNode *node; node = stack->top; if (stack->size != 0) { stack->top = node->next; stack->size--; } return node; } void stackClear(stack *stack) { unsigned long size; stackNode *current, *next; current = stack->top; size = stack->size; while (size--) { next = current->next; if (stack->free) stack->free(current->value); free(current); current = next; } free(stack); }
ここでの実装にはヘッド ノードが接続されており、主にスタック ノードの操作に関連する関数を登録するために使用されます。また、スタック サイズ情報も保存するので、現在のスタック サイズを O(1) 時間で取得できます。
Python の実装
Python では、リストの一端のみを操作する場合、実際にはリストをスタックとして直接使用できます。もちろん、単純にカプセル化することもできます:
class Stack(object): """A stack encapsulation based on list.""" def __init__(self): self.items = [] def empty(self): return self.items == [] def clear(self): del self.items[:] @property def size(self): return len(self.items) def push(self, item): """Add a new item to the top of the stack.""" self.items.insert(0, item) def pop(self): """Remove the top item from the stack.""" return self.items.pop(0) def top(self): """Return the top item from the stack but not remove it. """ return self.items[0] def __iter__(self): return iter(self.items) def __next__(self): return self.pop()
Application
以下では、スタックの典型的なアプリケーションをいくつか紹介します。
括弧の一致
算術式または C コードの一部が与えられた場合、その中の括弧が一致するかどうかを検証するプログラムをどのように作成すればよいでしょうか?スタックを利用すると、これを簡単に実現できます。アルゴリズム フローは次のとおりです:
文字のトラバース:
1. 左括弧の場合、スタックにプッシュします。
2. 右括弧の場合、この時点でスタックが空の場合スタックが空でない場合、ポップ スタックの左括弧と右括弧の型が異なるため、不一致を示します。
スタックが空でない場合。 、不一致を示します。
def check_pares(exp): """Check if parentheses match in a expression.""" stack = Stack() pares = {')': '(', ']': '[', '}': '{'} for x in exp: if x in '([{': stack.push(x) elif x in ')]}': if stack.empty() or pares[x] != stack.pop(): return False return True if stack.empty() else False
数体系の変換
10 進数から 2 進数への変換を例に挙げます。
def dec2bin(dec): """Converting decimal number to binary string.""" if dec == 0: return '0' stack = Stack() while dec: r = dec % 2 stack.push(r) dec = dec // 2 return ''.join(str(digit) for digit in stack)
再帰のシミュレーション
バイナリ ツリーのトラバースは、古典的な再帰アプリケーションです。プリオーダートラバーサルを例に挙げてみましょう。コードの再帰バージョンは簡単に記述できます:
def preorder_traversal(root): """ 1 / \ 2 3 / \ \ 4 5 6 """ if not root: return print(root.val) preorder_traversal(root.lchild) preorder_traversal(root.rchild)
以下は非再帰バージョンです:
def preorder_traversal(root) s = Stack() while s.size or root: if root: print(root.val) s.push(root) root = root.lchild else: root = s.pop().rchild
概要
上記は C 言語の使用方法とPython スタックと典型的なアプリケーションを実装するための内容は、皆様の学習に役立つことを願っています。また、皆様には引き続き PHP 中国語 Web サイトをサポートしていただければ幸いです。
C 言語と Python を使用してスタックと一般的なアプリケーションを実装する方法に関するその他の記事については、PHP 中国語 Web サイトに注目してください。

Pythonは、データサイエンス、Web開発、自動化タスクに適していますが、Cはシステムプログラミング、ゲーム開発、組み込みシステムに適しています。 Pythonは、そのシンプルさと強力なエコシステムで知られていますが、Cは高性能および基礎となる制御機能で知られています。

2時間以内にPythonの基本的なプログラミングの概念とスキルを学ぶことができます。 1.変数とデータ型、2。マスターコントロールフロー(条件付きステートメントとループ)、3。機能の定義と使用を理解する4。

Pythonは、Web開発、データサイエンス、機械学習、自動化、スクリプトの分野で広く使用されています。 1)Web開発では、DjangoおよびFlask Frameworksが開発プロセスを簡素化します。 2)データサイエンスと機械学習の分野では、Numpy、Pandas、Scikit-Learn、Tensorflowライブラリが強力なサポートを提供します。 3)自動化とスクリプトの観点から、Pythonは自動テストやシステム管理などのタスクに適しています。

2時間以内にPythonの基本を学ぶことができます。 1。変数とデータ型を学習します。2。ステートメントやループの場合などのマスター制御構造、3。関数の定義と使用を理解します。これらは、簡単なPythonプログラムの作成を開始するのに役立ちます。

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法

Python 3.6のピクルスファイルのロードレポートエラー:modulenotFounderror:nomodulenamed ...

風光明媚なスポットコメント分析におけるJieba Wordセグメンテーションの問題を解決する方法は?風光明媚なスポットコメントと分析を行っているとき、私たちはしばしばJieba Wordセグメンテーションツールを使用してテキストを処理します...


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

Dreamweaver Mac版
ビジュアル Web 開発ツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 中国語版
中国語版、とても使いやすい
