Python
 Computer >> コンピューター >  >> プログラミング >> Python

Pythonで解決されたUnixスタイルのパスを見つけるプログラム


文字列のリストにUnixパスがあるとすると、解決されたバージョンを見つける必要があります。 Unixで知っているように、「..」は前のディレクトリを示し、「。」は前のディレクトリを示します。現在のディレクトリにとどまることを示します。ここで解決すると、2つのシンボルが評価され、現在の最終的なディレクトリが取得されます。

したがって、入力がpath =["usr"、 ".."、 "usr"、 "。"、 "local"、 "etc"、 "foo"]の場合、出力は['usr'、 'local'、'etc'、'foo']、一部は「/usr/../usr/./local/etc」を表し、「/ usr / local / etc/foo」に解決されます

これを解決するには、次の手順に従います-

  • s:=新しいリスト
  • パス内の要素iごとに、
      を実行します。
    • iが'..'と同じ場合、
      • sが空でない場合、
        • sから最後の要素を削除する
    • それ以外の場合、iが「。」と同じでない場合は
      • sの最後にiを挿入
  • return s

理解を深めるために、次の実装を見てみましょう-

class Solution:
   def solve(self, path):
      s = []
      for i in path:
         if i == '..':
            if len(s) >0:
               s.pop()
            elif i !='.':
               s.append(i)
      return s
ob = Solution()
print(ob.solve(["usr", "..", "usr", ".", "local", "etc", "foo"]))

入力

["usr", "..", "usr", ".", "local", "etc", "foo"]

出力

['usr', 'local', 'etc', 'foo']

  1. 行列の転置を見つけるPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 行列が与えられた場合、転置を同じ行列に格納して表示する必要があります。 行列の転置は、行を列に、列を行に変更することで得られます。つまり、A行列の転置はA[i][j]をA[j][i]に変更することで得られます。 以下に示す実装を見てみましょう- 例 N = 4 def transpose(A):    for i in range(N):       for j in range(i+1, N):     &nbs

  2. 配列の合計を見つけるPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 入力として配列が与えられた場合、与えられた配列の合計を計算する必要があります。 ここでは、ブルートフォースアプローチに従うことができます。つまり、リストをトラバースし、各要素を空の合計変数に追加します。最後に、合計の値を表示します。 以下で説明するように、組み込みの合計関数を使用して別のアプローチを実行することもできます。 例 # main arr = [1,2,3,4,5] ans = sum(arr,n) print ('Sum of the array is '