亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目次
フィボナッチ級數(shù)ロジック
フィボナッチ數(shù)列の様々な作成方法
1.反復(fù)的なアプローチ
2.再帰的メソッド
3. Array
フィボナッチ數(shù)列の N 項を見つける方法は?
方法 2
結(jié)論

C# のフィボナッチ數(shù)列

Sep 03, 2024 pm 03:34 PM
c# c# tutorial

フィボナッチ數(shù)列のC#におけるフィボナッチ數(shù)列は有名な數(shù)列の一つです。シーケンスは 0、1、1、2、3、5、8... です。フィボナッチ數(shù)列は 0 と 1 から始まり、次の數(shù)値は前の 2 つの數(shù)値の合計になります。フィボナッチ數(shù)列は13世紀にレオナルド?ピサーノ?ビゴッロ氏によって作成されたと言われています。フィボナッチ數(shù)列は、いくつかのシナリオで役立ちます?;镜膜?、それはもともとウサギの問題、つまりつがいから生まれるウサギの數(shù)を解くために使用されました。フィボナッチ數(shù)列が役立つ問題は他にもあります。

フィボナッチ級數(shù)ロジック

フィボナッチ數(shù)列と同様、この數(shù)値は先行する 2 つの數(shù)値の合計です。したがって、フィボナッチ數(shù)列がある場合、0、1、1、2、3、5、8、13、21... この數(shù)字によれば、次の數(shù)字は 13 と 21 のように、前の 2 つの數(shù)字の合計になります。つまり、次の數(shù)字は 13 になります。 +21=34.

フィボナッチ數(shù)列を生成するロジックは次のとおりです

F(n)= F(n-1) +F(n-2)

ここで、F(n) は項番號、F(n-1) +F(n-2) は前の値の合計です。

シリーズ 0、1、1、2、3、5、8、13、21、34、55、89 があるとします…

ロジックによると、F(n)= F(n-1) +F(n-2)

F(n)= 55+89

F(n)= 144

次の期は 144 期になります。

フィボナッチ數(shù)列の様々な作成方法

フィボナッチ數(shù)列は複數(shù)の方法で生成できます。

1.反復(fù)的なアプローチ

この方法はシリーズを生成する最も簡単な方法です。

コード:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespaceFibonacciDemo
{
classProgram
{
staticint Fibonacci(int n)
{
intfirstnumber = 0, secondnumber = 1, result = 0;
if (n == 0) return 0; //It will return the first number of the series
if (n == 1) return 1; // it will return ?the second number of the series
for (int i = 2; i<= n; i++)? // main processing starts from here
{
result = firstnumber + secondnumber;
firstnumber = secondnumber;
secondnumber = result;
}
return result;
}
staticvoid Main(string[] args)
{
Console.Write("Length of the Fibonacci Series: ");
int length = Convert.ToInt32(Console.ReadLine());
for(int i = 0; i< length; i++)
{
Console.Write("{0} ", Fibonacci(i));
}
Console.ReadKey();
}
}
}

2.再帰的メソッド

これは、この問題を解決する別の方法です。

方法 1

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespaceFibonacciDemo
{
classProgram
{
staticint Fibonacci(int n)
{
intfirstnumber = 0, secondnumber = 1, result = 0;
if (n == 0) return 0; //it will return the first number of the series
if (n == 1) return 1; // it will return the second number of the series
return Fibonacci(n-1) + Fibonacci(n-2);
}
staticvoid Main(string[] args)
{
Console.Write("Length of the Fibonacci Series: ");
int length = Convert.ToInt32(Console.ReadLine());
for(int i = 0; i< length; i++)
{
Console.Write("{0} ", Fibonacci(i));
}
Console.ReadKey();
}
}
}

方法 2

using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace FibonacciSeries
{
class Program
{
public static void Fibonacci
(
int firstnumber,
int secondnumber,
int count,
int length,
)
{
if (count <= length)
{
Console.Write("{0} ", firstnumber);
Fibonacci(secondnumber, firstnumber + secondnumber, count + 1, length);
}
}
public static void Main(string[] args)
{
Console.Write("Length of the Fibonacci Series: ");
int length = Convert.ToInt32(Console.ReadLine());
Fibonacci(0, 1, 1, length);
Console.ReadKey();
}
}
}

出力:

C# のフィボナッチ數(shù)列

3. Array

を使用したフィボナッチ

コード:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
public class Program
{
public static int[] Fibonacci(int number)
{
int[] a = new int[number];
a[0] = 0;
a[1] = 1;
for (int i = 2; i < number; i++)
{
a[i] = a[i - 2] + a[i - 1];
}
return a;
}
public static void Main(string[] args)
{
var b = Fibonacci(10);
foreach (var elements in b)
{
Console.WriteLine(elements);
}
}
}

出力:

C# のフィボナッチ數(shù)列

フィボナッチ數(shù)列の N 項を見つける方法は?

以下の方法があります

方法 1

コード:

using System;
namespace FibonacciSeries
{
class Program {
public static int NthTerm(int n)
{
if ((n == 0) || (n == 1))
{
return n;
}
else
{
return (NthTerm(n - 1) + NthTerm(n - 2));
}
}
public static void Main(string[] args)
{
Console.Write("Enter the nth term of the Fibonacci Series: ");
int number = Convert.ToInt32(Console.ReadLine());
number = number - 1;
Console.Write(NthTerm(number));
Console.ReadKey();
}
}
}

上記のコードは、フィボナッチ數(shù)列の n 番目の項を見つけることです。たとえば、シリーズ內(nèi)の 12 番目 の用語を見つけたい場合、結(jié)果は 89 になります。

方法 2

(O(ログ t) 時間).

t 番目のフィボナッチ數(shù)を見つけるために使用できるもう 1 つの漸化式があります。t が偶數(shù)の場合 = t/2:

F(t) = [2*F(k-1) + F(k)]*F(k)

t が奇數(shù)の場合、k = (t + 1)/2

F(t) = F(k)*F(k) + F(k-1)*F(k-1)

フィボナッチ行列

行列式を取得した後、(-1)t = Ft+1Ft-1 – Ft2 を取得します

FmFt + Fm-1Ft-1 = Fm+t-1

t = t+1 とすると、

FmFt+1 + Fm-1Ft = Fm+t

m = t と置く

F2t-1 = Ft2 + Ft-12

F2t = (Ft-1 + Ft+1)Ft = (2Ft-1 + Ft)Ft

數(shù)式を取得するには、次の操作を行います

t が偶數(shù)の場合、k = t/2 とします

t が奇數(shù)の場合、k = (t+1)/2 とします

これらの數(shù)値を並べ替えることで、STACK のメモリ領(lǐng)域が常に使用されるのを防ぐことができます。それは O(n) の時間計算量を與えます。再帰的アルゴリズムは効率が低くなります。

コード:

int f(n) :
if( n==0 || n==1 )
return n;
else
return f(n-1) + f(n-2)

上記のアルゴリズムを n=4 で実行すると

fn(4)

f(3) f(2)

f(2) f(1) f(1) f(0)

f(1) f(0)

それは木です。 f(4) を計算するには、f(3) と f(2) などを計算する必要があります。4 という小さな値の場合、f(2) は 2 回計算され、f(1) は 3 回計算されます。この加算數(shù)は、數(shù)値が大きいほど大きくなります。

f (n) の計算に必要な加算回數(shù)は f (n+1) -1 であるという予想があります。

結(jié)論

ここでは、この種の問題をより迅速に解決できるため、反復(fù)法が常に好まれます。ここでは、フィボナッチ數(shù)列の最初と 2 番目の數(shù)値を前の數(shù)値と前の數(shù)値 (これらは 2 つの変數(shù)) に保存し、また現(xiàn)在の數(shù)値を使用してフィボナッチ數(shù)を保存しています。

以上がC# のフィボナッチ數(shù)列の詳細內(nèi)容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中國語版

SublimeText3 中國語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

マルチスレッドと非同期C#の違い マルチスレッドと非同期C#の違い Apr 03, 2025 pm 02:57 PM

マルチスレッドと非同期の違いは、マルチスレッドが複數(shù)のスレッドを同時に実行し、現(xiàn)在のスレッドをブロックせずに非同期に操作を?qū)g行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利點は、コンピューティングのパフォーマンスを改善することですが、非同期の利點はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質(zhì)に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

C#対C:歴史、進化、將來の見通し C#対C:歴史、進化、將來の見通し Apr 19, 2025 am 12:07 AM

C#とCの歴史と進化はユニークであり、將來の見通しも異なります。 1.Cは、1983年にBjarnestrostrupによって発明され、オブジェクト指向のプログラミングをC言語に導(dǎo)入しました。その進化プロセスには、C 11の自動キーワードとラムダ式の導(dǎo)入など、複數(shù)の標準化が含まれます。C20概念とコルーチンの導(dǎo)入、將來のパフォーマンスとシステムレベルのプログラミングに焦點を當(dāng)てます。 2.C#は2000年にMicrosoftによってリリースされました。CとJavaの利點を組み合わせて、その進化はシンプルさと生産性に焦點を當(dāng)てています。たとえば、C#2.0はジェネリックを?qū)毪贰#5.0は非同期プログラミングを?qū)毪筏蓼筏?。これは、將來の開発者の生産性とクラウドコンピューティングに焦點を當(dāng)てます。

XMLの形式を変更する方法 XMLの形式を変更する方法 Apr 03, 2025 am 08:42 AM

XML形式を変更する方法はいくつかあります。Atepadなどのテキストエディターを使用して手動で編集する。 XmlBeautifierなどのオンラインまたはデスクトップXMLフォーマットツールを使用して自動的にフォーマットします。 XSLTなどのXML変換ツールを使用して変換ルールを定義します。または、Pythonなどのプログラミング言語を使用して解析および操作します。元のファイルを変更してバックアップするときは注意してください。

XMLを単語に変換する方法 XMLを単語に変換する方法 Apr 03, 2025 am 08:15 AM

XMLを単語に変換するには、Microsoft Wordの使用、XMLコンバーターの使用、またはプログラミング言語の使用方法が3つあります。

XMLをJSONに変換する方法 XMLをJSONに変換する方法 Apr 03, 2025 am 09:09 AM

XMLをJSONに変換する方法は次のとおりです。プログラミング言語(Python、Java、C#など)でスクリプトまたはプログラムを作成して変換します。オンラインツール(XMLからJSON、GojkoのXMLコンバーター、XMLオンラインツールなど)を使用してXMLデータを貼り付けまたはアップロードし、JSON形式の出力を選択します。 XMLからJSONコンバーターを使用して変換タスクを?qū)g行します(酸素XMLエディター、Stylus Studio、Altova XMLSpyなど)。 XSLT StyleSheetsを使用してXMLをJSONに変換します。データ統(tǒng)合ツールを使用しています(Informaticなど

C#マルチスレッドプログラミングとは何ですか? C#マルチスレッドプログラミングでは、C#マルチスレッドプログラミングを使用します C#マルチスレッドプログラミングとは何ですか? C#マルチスレッドプログラミングでは、C#マルチスレッドプログラミングを使用します Apr 03, 2025 pm 02:45 PM

C#マルチスレッドプログラミングは、プログラムが複數(shù)のタスクを同時に実行できるようにするテクノロジーです。パフォーマンスを改善し、応答性を改善し、並列処理を?qū)g裝することにより、プログラムの効率を改善できます。スレッドクラスはスレッドを直接作成する方法を提供しますが、タスクやAsync/待望などの高度なツールは、より安全な非同期操作とクリーンなコード構(gòu)造を提供できます。マルチスレッドプログラミングの一般的な課題には、デッドロック、レース條件、リソースリークが含まれます。これらのリソースモデルの設(shè)計と、これらの問題を回避するために適切な同期メカニズムの使用が必要です。

C#.NET:.NETエコシステムを使用したアプリケーションの構(gòu)築 C#.NET:.NETエコシステムを使用したアプリケーションの構(gòu)築 Apr 27, 2025 am 12:12 AM

.NETを使用してアプリケーションを構(gòu)築する方法は? .NETを使用してアプリケーションを構(gòu)築することは、次の手順を通じて達成できます。1)C#言語やクロスプラットフォーム開発サポートを含む.NETの基本を理解します。 2)コンポーネントや.NETエコシステムの作業(yè)原則などのコア概念を?qū)W習(xí)します。 3)単純なコンソールアプリケーションから複雑なWebAPISおよびデータベース操作まで、基本的および高度な使用をマスターします。 4)構(gòu)成やデータベース接続の問題など、一般的なエラーとデバッグ手法に精通している。 5)アプリケーションのパフォーマンスの最適化と非同期プログラミングやキャッシュなどのベストプラクティス。

Webからデスクトップまで:C#.NETの汎用性 Webからデスクトップまで:C#.NETの汎用性 Apr 15, 2025 am 12:07 AM

c#.netisversatileforbothwebanddesktopdevelopment.1)forweb、useasp.netfordynamicapplications.2)fordesktop、equindowsorwpfforrichinterfaces.3)usexamarinforcross-platformdeveliment、enabling deshacrosswindows、

See all articles