
ディレクトリ構造の変更前と変更後の比較を行って、
どのフォルダがどこへ行ったかを判別するプログラムを作成したいのですが、どんなアルゴリズムにすればよいでしょうか?
変更前と変更後でディレクトリは1:1に対応しません。n:mや削除、追加など色んなパターンがあります。
ツリー構造(ディレクトリ構造)とは、以下のようなイメージのものです。
C:.
├─Acrobat
│ ├─ActiveX
│ ├─Browser
│ ├─FileInfo
│ ├─HowTo
│ │ ├─ENU
│ │ │ └─Images
│ │ └─JPN
│ │ └─Images
│ ├─Javascripts
No.1ベストアンサー
- 回答日時:
考えてみましたが何とも言えません。
取り敢えず回答カウントがゼロなので投稿させていただきます。
但し、これはあくまで個人的なアイデアやイメージである事を前提とします。
☆ツリー構造はGUIコントロールでありマウスで操作するとコールバックされる事を前提(TreeGUIとします)
☆手順はコールバックがかかる度に変化したTreeGUIの状態からデータ構造を生成します
☆データ型
struct TreeData
{
string strDirectory;//ディレクトリの名前 "Actobat"など
int nAction;//このディレクトリに対して行われた操作フラグの記録
//その他TreeDataを連結するポインタなど
};
☆page[?]//TreeData*をしまう為の配列
page[0]//変更前
page[1]//変更後
(1)以下のスタートの状態からTreeDataを生成してpage[0]に入れる
├─Acrobat
│ ├─ActiveX
│ ├─Browser
│ ├─FileInfo
│ ├─HowTo
│ │ ├─ENU
│ │ │ └─Images
│ │ └─JPN
│ │ └─Images
│ ├─Javascripts
(2)TreeGUIをマウスで突っついたりディレクトリ操作をする(コールバック発生)TreeGUIの状態かTreeDataを生成してpage[1]に入れる
アルゴリズム等
1:1やm:nの確認なら再帰等で操作してCTreeDataの連結数を数えて比較すれば出来ます
oldCount = DoCount(page[0])
nowCount = DoCount(page[1])
ディレクトリの位置が違うがカウントは同じ
if(oldCount == nowCount)//...
あとはTreeDataの構造を操作しながらその都度処理していくしかなさそうです。当然ながらどのような操作を受けたディレクトリなのかを示すメンバデータも必要になります。
また変更前と変更後の二つだけしか必要ない場合、TreeGUIに反応するたびpage[1]にTreeData生成しますが、一歩手前を検出する場合は変更以前のものが軌跡を残すように連鎖するので(アンドゥリドゥみたいになる)pageは動的に拡大されます(page[0] ~ page[n])。
この設問に回答するのは実に困難であります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(開発・運用・管理) フォルダの中にファルダを作成してファイルを格納するバッチコマンド 1 2022/06/30 11:39
- 車検・修理・メンテナンス 人から安く手に入れたムーブを構造変更にバンにしようと思っていますが、名義変更がまだであり、車検も7月 3 2022/06/28 22:15
- UNIX・Linux JSLinuxについて。 Linuxのこの手順のプログラミングは合っているでしょうか。 ①ホームディ 2 2022/06/20 15:33
- Windows 10 バッチファイルの記述法とルールについてアドバイスをお願いいたします。 1 2022/04/13 10:50
- カスタマイズ(車) ロアアームやアッパーアームを交換した場合 構造変更なのか記載変更なのか どっちをしなきゃいけないのか 2 2022/10/05 15:35
- YouTube 動画再生回数のねつ造の今後について 1 2023/07/04 07:03
- バイク車検・修理・メンテナンス バイク 車検 名義変更 構造変更について。 親から一時抹消されていない、400cc車検切れのバイクを 1 2023/04/22 18:31
- その他(プログラミング・Web制作) 図に示す階層構造で,現在のディレクトリ(カレントディレクトリという)が*印のディレクトリであるとき, 2 2022/11/16 10:55
- PostgreSQL PostgressからMySQL(MariaDB)へ構造を変更する際のTimestamp等について 2 2023/04/04 12:09
- 貨物自動車・業務用車両 自家用の軽自動車は、軽貨物車として構造変更が可能? 3 2023/01/10 23:58
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Subversionのリポジトリの削除
-
FTPコマンドでディレクトリごと...
-
バッチを用いたフォルダの自動移動
-
CFileDialogの最初のディレクト...
-
カウンターの作り方
-
visualstudioでc#のdllができない
-
ファイル・ディレクトリ削除を...
-
FTPでのファイルとディレクトリ...
-
ツリー構造の比較のアルゴリズ...
-
Subversionで、ファイルをリネ...
-
preg_match関数で正規表現の複...
-
SSH2で対象ホストのディレクト...
-
現在位置より2つ上のディレク...
-
サーバー上にディレクトリを作...
-
ディレクトリ以下のファイル名...
-
Makefile.inとMakefile.am
-
コマンドプロンプトを指定のデ...
-
UWSCでファイルのアップロード...
-
LinuxからNASを使用したときの...
-
バッチファイルで特定ファイル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
FTPコマンドでディレクトリごと...
-
Subversionのリポジトリの削除
-
バッチを用いたフォルダの自動移動
-
CFileDialogの最初のディレクト...
-
visualstudioでc#のdllができない
-
rmdirでフォルダが消せません
-
makefile でファイルをコピーす...
-
現在位置より2つ上のディレク...
-
VB2008でFTPでのディ...
-
FTPでのファイルとディレクトリ...
-
VC#のFtpWebRequestで多階層の...
-
renameでのPermission deniedエ...
-
http://localhost/に.htaccess...
-
絶対パス?絶対アドレス?意味...
-
powershell で書いたプログラム...
-
fopenでファイルが開かない場合...
-
上位ディレクトリ名(フォルダ...
-
kshのスクリプトでワイルドカー...
-
aspのページが表示できません
-
コマンドプロンプトを指定のデ...
おすすめ情報