国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
フィボナッチ級數(shù)ロジック
フィボナッチ數(shù)列の様々な作成方法
1.反復(fù)的なアプローチ
2.再帰的メソッド
3. Array
フィボナッチ數(shù)列の N 項(xiàng)を見つける方法は?
方法 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ù)値の合計(jì)になります。フィボナッチ數(shù)列は13世紀(jì)にレオナルド?ピサーノ?ビゴッロ氏によって作成されたと言われています。フィボナッチ數(shù)列は、いくつかのシナリオで役立ちます。基本的に、それはもともとウサギの問題、つまりつがいから生まれるウサギの數(shù)を解くために使用されました。フィボナッチ數(shù)列が役立つ問題は他にもあります。

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

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

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

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

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

シリーズ 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 項(xiàng)を見つける方法は?

以下の方法があります

方法 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 番目の項(xiàng)を見つけることです。たとえば、シリーズ內(nèi)の 12 番目 の用語を見つけたい場合、結(jié)果は 89 になります。

方法 2

(O(ログ t) 時(shí)間).

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) の時(shí)間計(jì)算量を與えます。再帰的アルゴリズムは効率が低くなります。

コード:

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) を計(jì)算するには、f(3) と f(2) などを計(jì)算する必要があります。4 という小さな値の場合、f(2) は 2 回計(jì)算され、f(1) は 3 回計(jì)算されます。この加算數(shù)は、數(shù)値が大きいほど大きくなります。

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

結(jié)論

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

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

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、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

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

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

C# の亂數(shù)ジェネレーター C# の亂數(shù)ジェネレーター Sep 03, 2024 pm 03:34 PM

C# の亂數(shù)ジェネレーターのガイド。ここでは、亂數(shù)ジェネレーターの仕組み、擬似亂數(shù)の概念、安全な數(shù)値について説明します。

C# の階乗 C# の階乗 Sep 03, 2024 pm 03:34 PM

C# の Factorial のガイド。ここでは、C# での階乗の概要について、さまざまな例とコード実裝とともに説明します。

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

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

C# の素?cái)?shù) C# の素?cái)?shù) Sep 03, 2024 pm 03:35 PM

C# の素?cái)?shù)ガイド。ここでは、C# における素?cái)?shù)の導(dǎo)入と例を、コードの実裝とともに説明します。

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

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

C# のパターン C# のパターン Sep 03, 2024 pm 03:33 PM

C# のパターンのガイド。ここでは、C# のパターンの概要と上位 3 種類について、その例とコード実裝とともに説明します。

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

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

C# の回文 C# の回文 Sep 03, 2024 pm 03:34 PM

C# の回文のガイド。ここでは、C# の回文の概要とロジック、およびそのコードを使用したさまざまなメソッドについて説明します。

See all articles