プログラムの先頭で、操作を高速化するために事前フィルタリングを実行し、負の数や最後の 4 桁が 0 である数値など、明らかな非平方数をフィルタリングして除外します。 、および特定の要件を満たす最後の 2 桁の数字 (10 進数で 5 または 8)。 0 については、平方数と考えてください。
次に、ビット単位の手法を使用して、モジュロ 255 = 3 = 3 5 17 の剰余が平方数であるかどうかを確認します。配列 bad255 は、各剰余が平方数であるかどうかを記録します。テーブルの上に。
プレフィルターを通過した数値については、商が奇数になるまで 2 のすべてのべき乗で (二分探索法で) 除算します。
最後のステップは、ヘンゼルの補題と同様の方法を使用して平方根を近似することです。内側のループは、開始配列によって指定された初期値で始まり、sqrt (mod 8192) の近似値が得られます。この近似は、ビットごとのトリックを使用して速度を向上させ、連続的な計算を通じて継続的に改善されます。
このメソッドの大まかな構造は次のとおりです。
- 明らかな非平方数を除去するためのプレフィルター。
- 255 を法とした剰余が平方数であるかどうかを確認します。
- 2 の累乗で割ります。
- ヘンゼルの補題の変形を使用して平方根を近似的に計算します。
このアルゴリズムの作成者が、他の方法よりも 35% 高速に実行できると主張していることは注目に値します。
以上が大きな数が完全二乗であるかどうかを効率的に判断するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ドリームウィーバー CS6
ビジュアル Web 開発ツール
