ホームページ バックエンド開発 Python チュートリアル Python関数の再帰とジェネレーター

Python関数の再帰とジェネレーター

Mar 03, 2017 pm 03:08 PM
python

1. 再帰とは

関数にそれ自体への呼び出しが含まれる場合、その関数は再帰的です。再帰はアルゴリズムとしてプログラミング言語で広く使用されており、通常、大規模で複雑な問題を元の問題と同様の小さな問題に変換します。再帰戦略は、複数の反復計算のみで記述できます。問題を解決するために必要なコード量が大幅に削減されます。たとえば、1 ~ 9 の 9 桁の数値の積を計算する場合、1 ~ 10000 の積を計算する場合の直感的なアルゴリズムは 1*2*3*4*5*6*7*8*9 です。 、直感的なアルゴリズムの実装は難しいですが、再帰は簡単に実装できます。例を見てください:

def fact(n):#计算给定数字到一的乘积
   if n<=1:
     return 1
   else:
     return n * fact(n-1) 
print (fact(7))
ログイン後にコピー

結果は次のとおりです: 5040

再帰的な実行プロセスを確認するために例を使用してみましょう:

def calc(n):
   print(n)
   if n/2 > 1:
     res = calc(n/2)
   return n
 calc(8)
ログイン後にコピー

結果は次のとおりです:

えー

この例をもう一度見てください:

8
4.0
2.0
ログイン後にコピー

結果は次のようになります:

def calc(n):
  print(n)
  if n/2 > 1:
    res = calc(n/2)
    print(&#39;res:&#39;,res)
  print("N:",n)
  return n
calc(8)
ログイン後にコピー

2. ジェネレーター ジェネレーターは収量のある関数です声明 。関数またはサブルーチンは 1 回しか戻りませんが、ジェネレーターは実行を一時停止して中間結果を返したり、呼び出し元に値を返して実行を一時停止したりできます。ジェネレーターの next() メソッドが呼び出されると、中断したところから正確に続行されます

以下の例を見てください:

8
4.0
2.0
N: 2.0
res: 2.0
N: 4.0
res: 4.0
N: 8
ログイン後にコピー

結果は次のようになります:

def func():
  print(&#39;11111111&#39;)
  yield [1]
  print(2222222222)
  yield 2
  print(3333333333)
  yield 3

ret=func()
r1=ret.__next__()
print(r1)
r2=ret.__next__()
print(r2)
r3=ret.__next__()
print(r3)
ログイン後にコピー

Python のループには next() 呼び出しと StopIteration の処理があり、ジェネレーター (またはそのイテレーター) を手動で反復処理する代わりに、for ループを使用するほうがずっとクリーンで見栄えがよくなります。例:

11111111
[1]
2222222222
2
3333333333
3
ログイン後にコピー

結果は前と同じです。

これらの簡単な例は、ジェネレーターがどのように機能するかを少し理解できるはずです。次に生成された値を取得する next() に加えて、ユーザーはジェネレーターに値を送り返したり [send()]、ジェネレーターで例外をスローしたり、ジェネレーターに終了を要求したりすることができます [close()]

はこちらデモンストレーション これらの機能の簡単な例。

def func():
  print(&#39;11111111&#39;)
  yield [1]
  print(2222222222)
  yield 2
  print(3333333333)
  yield 3
ret=func()
for i in ret:
  print(i)
ログイン後にコピー

ジェネレーターには、ジェネレーター [next()] を呼び出すたびに 1 ずつカウントアップする初期化された値が付属しています。本当に next() を呼び出す代わりに新しい値で send() を呼び出したい場合、ユーザーにはこの値をリセットするオプションがあります。このジェネレーターは永久に実行されるため、終了したい場合は close() メソッドを呼び出します。このコードを対話的に実行すると、次の出力が得られます:

def counter(start_at=0):
  count = start_at
  while True:
    val = (yield count) if val is not None:
    count = val
  else:
    count += 1
ログイン後にコピー

Python 関数の再帰とジェネレーターの詳細な理解に関する上記の記事は、エディターによって共有されたすべての内容です。また、皆さんも PHP 中国語 Web サイトをサポートしていただければ幸いです。

Python 関数の再帰とジェネレーターに関連するその他の記事については、PHP 中国語 Web サイトに注目してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

携帯電話でXMLをPDFに変換するとき、変換速度は高速ですか? 携帯電話でXMLをPDFに変換するとき、変換速度は高速ですか? Apr 02, 2025 pm 10:09 PM

Mobile XMLからPDFへの速度は、次の要因に依存します。XML構造の複雑さです。モバイルハードウェア構成変換方法(ライブラリ、アルゴリズム)コードの品質最適化方法(効率的なライブラリ、アルゴリズムの最適化、キャッシュデータ、およびマルチスレッドの利用)。全体として、絶対的な答えはなく、特定の状況に従って最適化する必要があります。

携帯電話のXMLファイルをPDFに変換する方法は? 携帯電話のXMLファイルをPDFに変換する方法は? Apr 02, 2025 pm 10:12 PM

単一のアプリケーションで携帯電話でXMLからPDF変換を直接完了することは不可能です。クラウドサービスを使用する必要があります。クラウドサービスは、2つのステップで達成できます。1。XMLをクラウド内のPDFに変換し、2。携帯電話の変換されたPDFファイルにアクセスまたはダウンロードします。

C言語合計の機能は何ですか? C言語合計の機能は何ですか? Apr 03, 2025 pm 02:21 PM

C言語に組み込みの合計機能はないため、自分で書く必要があります。合計は、配列を通過して要素を蓄積することで達成できます。ループバージョン:合計は、ループとアレイの長さを使用して計算されます。ポインターバージョン:ポインターを使用してアレイ要素を指し示し、効率的な合計が自己概要ポインターを通じて達成されます。アレイバージョンを動的に割り当てます:[アレイ]を動的に割り当ててメモリを自分で管理し、メモリの漏れを防ぐために割り当てられたメモリが解放されます。

XMLをPDFに変換できるモバイルアプリはありますか? XMLをPDFに変換できるモバイルアプリはありますか? Apr 02, 2025 pm 09:45 PM

XML構造が柔軟で多様であるため、すべてのXMLファイルをPDFSに変換できるアプリはありません。 XMLのPDFへのコアは、データ構造をページレイアウトに変換することです。これには、XMLの解析とPDFの生成が必要です。一般的な方法には、ElementTreeなどのPythonライブラリを使用してXMLを解析し、ReportLabライブラリを使用してPDFを生成することが含まれます。複雑なXMLの場合、XSLT変換構造を使用する必要がある場合があります。パフォーマンスを最適化するときは、マルチスレッドまたはマルチプロセスの使用を検討し、適切なライブラリを選択します。

推奨されるXMLフォーマットツール 推奨されるXMLフォーマットツール Apr 02, 2025 pm 09:03 PM

XMLフォーマットツールは、読みやすさと理解を向上させるために、ルールに従ってコードを入力できます。ツールを選択するときは、カスタマイズ機能、特別な状況の処理、パフォーマンス、使いやすさに注意してください。一般的に使用されるツールタイプには、オンラインツール、IDEプラグイン、コマンドラインツールが含まれます。

携帯電話でXMLをPDFに変換する方法は? 携帯電話でXMLをPDFに変換する方法は? Apr 02, 2025 pm 10:18 PM

携帯電話でXMLをPDFに直接変換するのは簡単ではありませんが、クラウドサービスの助けを借りて実現できます。軽量モバイルアプリを使用してXMLファイルをアップロードし、生成されたPDFを受信し、クラウドAPIで変換することをお勧めします。クラウドAPIはサーバーレスコンピューティングサービスを使用し、適切なプラットフォームを選択することが重要です。 XMLの解析とPDF生成を処理する際には、複雑さ、エラー処理、セキュリティ、および最適化戦略を考慮する必要があります。プロセス全体では、フロントエンドアプリとバックエンドAPIが連携する必要があり、さまざまなテクノロジーをある程度理解する必要があります。

XMLを写真に変換する方法 XMLを写真に変換する方法 Apr 03, 2025 am 07:39 AM

XMLは、XSLTコンバーターまたは画像ライブラリを使用して画像に変換できます。 XSLTコンバーター:XSLTプロセッサとスタイルシートを使用して、XMLを画像に変換します。画像ライブラリ:PILやImageMagickなどのライブラリを使用して、形状やテキストの描画などのXMLデータから画像を作成します。

XML形式を開く方法 XML形式を開く方法 Apr 02, 2025 pm 09:00 PM

ほとんどのテキストエディターを使用して、XMLファイルを開きます。より直感的なツリーディスプレイが必要な場合は、酸素XMLエディターやXMLSPYなどのXMLエディターを使用できます。プログラムでXMLデータを処理する場合、プログラミング言語(Pythonなど)やXMLライブラリ(XML.ETREE.ELEMENTTREEなど)を使用して解析する必要があります。

See all articles