WrappedStack ライブラリ

- 目次 -


概要 - Abstract

このライブラリ data.WrappedStack は、スタック型のデータ構造を提供します。

このモジュールでは、スタックのデータを保持するジェネリック構造体 WrappedStack と、それに対してデータを出し入れするジェネリック関数 push, pop などが提供されます。

なお、この data.WrappedStack では、要素を DataWrapper 構造体でラッピングして保持する実装になっています。
そのため WrappedStackでは、 data.Stack とは異なり、配列を要素として扱う事ができます。

反面、要素の出し入れの際に DataWrapper 構造体へのラッピング処理を伴うため、そのオーバーヘッドの分だけ、Stack よりも処理が重くなります。
従って、要素が配列でない場合には、WrappedStack よりも Stack の使用が推奨されます。


目次 - Index

struct WrappedStack<Type>
スタック構造体です。スタックのデータを保持します。
void clear<Type>( WrappedStack<Type> &stack )
要素を全て削除します。
int size<Type>( WrappedStack<Type> &stack )
使用中のサイズを返します。
void push<Type>( WrappedStack<Type> &stack, Type value )
スタックに要素を追加します。
Type pop<Type>( WrappedStack<Type> &stack )
スタックから要素を取り出します。取り出した要素は、スタックから削除されます。
Type peek<Type>( WrappedStack<Type> &stack )
スタックから要素を削除せずに取り出します。
bool contains<Type>( WrappedStack<Type> &stack, Type element )
スタックが指定された要素を含んでいるか判定します。
void reverse<Type>( WrappedStack<Type> &stack )
スタックが保持する全要素の順序を反転させます。
DataWrapper<Type>[ ] toDataWrapperArray<Type>( WrappedStack<Type> &stack )
スタックが保持する全要素を、DataWrapper配列に格納して返します。なお、順序は pop や peek で最初に得られる要素を格納するものが [ 0 ] になります。

構造体 - Structs

文法的定義
- Signature
struct WrappedStack<Type>
構造体名
- Name
WrappedStack<Type>
役割
- Role
スタック構造体です。スタックのデータを保持します。

変数 - Variables

- なし - None -


関数 - Functions

文法的定義
- Signature
void clear<Type>( WrappedStack<Type> &stack )
関数名
- Name
clear<Type>
役割
- Role
要素を全て削除します。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
戻り値
- Return
(void型)
文法的定義
- Signature
int size<Type>( WrappedStack<Type> &stack )
関数名
- Name
size<Type>
役割
- Role
使用中のサイズを返します。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
戻り値
- Return
(int型)
文法的定義
- Signature
void push<Type>( WrappedStack<Type> &stack, Type value )
関数名
- Name
push<Type>
役割
- Role
スタックに要素を追加します。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
(Type型) value : 追加する要素
戻り値
- Return
(void型)
文法的定義
- Signature
Type pop<Type>( WrappedStack<Type> &stack )
関数名
- Name
pop<Type>
役割
- Role
スタックから要素を取り出します。取り出した要素は、スタックから削除されます。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
戻り値
- Return
(Type型) 取り出した要素
文法的定義
- Signature
Type peek<Type>( WrappedStack<Type> &stack )
関数名
- Name
peek<Type>
役割
- Role
スタックから要素を削除せずに取り出します。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
戻り値
- Return
(Type型) 取り出した要素
文法的定義
- Signature
bool contains<Type>( WrappedStack<Type> &stack, Type element )
関数名
- Name
contains<Type>
役割
- Role
スタックが指定された要素を含んでいるか判定します。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
(Type型) element : 含まれるか判定したい要素
戻り値
- Return
(bool型)
文法的定義
- Signature
void reverse<Type>( WrappedStack<Type> &stack )
関数名
- Name
reverse<Type>
役割
- Role
スタックが保持する全要素の順序を反転させます。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
戻り値
- Return
(void型)
文法的定義
- Signature
DataWrapper<Type>[ ] toDataWrapperArray<Type>( WrappedStack<Type> &stack )
関数名
- Name
toDataWrapperArray<Type>
役割
- Role
スタックが保持する全要素を、DataWrapper配列に格納して返します。なお、順序は pop や peek で最初に得られる要素を格納するものが [ 0 ] になります。
引数
- Arguments
(WrappedStack<Type>型) stack : 対象のスタック構造体
戻り値
- Return
(DataWrapper<Type>[]型) スタックの全要素をまとめたDataWrapper配列


スポンサーリンク



この階層の目次
RINEARN からのお知らせ
※ VCSSL は RINEARN が開発しています。

ExevalatorのVer.2.4をリリース—MCPをサポートし、AI用の計算ツールとしても使用可能に
2025-11-15 - 式計算ライブラリExevalatorのVer.2.4をリリースしました。今回から、AIとやり取りするためのプロトコルである「MCP」をサポートし、AI用の計算ツールとしても使用可能になりました!

Exevalatorの最新版Ver.2.3をリリース、新たにPythonで使用可能に
2025-11-04 - 式計算ライブラリExevalatorのVer.2.3をリリースしました。今回から、新たにPython製のプログラムでも使用可能になりました!AI用ツール開発需要などの背景も踏まえて、詳細をお知らせします。

Exevalatorをアップデート、エラーメッセージの日本語化が手軽に
2025-10-31 - 式計算ライブラリExevalatorのVer.2.2.2をリリースしました。今回から、エラーメッセージを手軽に日本語化できるようになりました。数件のバグ修正&微調整も作んでいます。詳細をお知らせします。

関数電卓RINPn(りんぷん)オンライン版の内部構造を解説
2025-10-22 - 先日登場した、関数電卓ソフトRINPn(りんぷん)のオンライン版の内部構造を解説します。オープンソースなので、自由に改造・流用して、自分だけのWeb電卓を作る事も可能!(かもしれない)

関数電卓RINPn(りんぷん)、どこでもすぐ使えるオンライン版が登場!
2025-10-21 - フリー関数電卓ソフトRINPn(りんぷん)に、Web上でどこでもすぐ使える「オンライン版」が新登場しました!PCだけでなく、スマホでも利用可能です。詳細をお知らせします!

VCSSLのサポートAIが登場!ただし実用品質にはChatGPT有料アカウント(Plus)での利用推奨
2025-08-19 - プログラミング言語VCSSLについての質問対応や、コーディング作業を手伝ってくれるAIさんが登場しました!使用までの流れや推奨事項を解説し、実際の回答例や生成コード例などもたくさん紹介します!

各ソフトやVCSSLの英語版ドキュメント整備がほぼ完了
2025-06-30 - RINEARNでは2年前から、AIの補助による英語版ドキュメントの大幅拡充計画を進めてきました。今回、主要ドキュメント&コンテンツの英訳がほぼ完了し、一応の目標水準に達しました。詳細をお知らせします。

VCSSLの最新版をリリース:外部プログラムとの連携機能を少し強化、他
2025-05-25 - VCSSL3.4.52をリリースしました。外部プログラム(C言語製の実行ファイル等)との連携機能を少し強化し、文字化け対策やOS判別などを可能にしました。他にも細かい機能追加があります。詳細をお知らせします。

VCSSLの最新版をリリース、Java24上での非互換な挙動を対処
2025-04-22 - VCSSL3.4.50をリリースしました。Java24環境上でのネットワークドライブ関連のファイルパス解決で、従来環境とは異なる挙動が生じていたのを解消しました。詳細をお知らせします。

リニアングラフやVCSSLの最新版をリリース、目盛りの位置や内容を自由に指定可能に!
2024-11-24 - リニアングラフ3D/2Dを更新し、自由な位置に、自由な表記内容の目盛りを描けるようになりました!併せて、Java言語やVCSSLでの、プログラム制御用APIも拡張しています。詳細をお知らせします。