中点ライン生成アルゴリズムの C++ 実装
- #DDA アルゴリズム
- #ブレゼンハム ライン生成
- #中点アルゴリズム
- #中点アルゴリズム#中点を使用して線を描く手順 点線アルゴリズムは、-
## です。 #Use 現在の測位点は中点、つまり東(Xp 1, Yp)と北東(Xp 1, Yp) 1)を中点(Xp 1, Yp 1/2)として計算します。
- これで、中点によって画面上の次の座標の位置が決まります。つまり、
- 中点が線の上にある場合、次の座標が決まります。東になります。
-
p>
- 中点が線より下にある場合、次の座標は北東になります。
- #さまざまな入出力シナリオを見てみましょう- Input
output
outputstrong>- ライン生成アルゴリズムの中点は次のとおりです: 3,3 4 ,4 5,5 6,5 7,6 8,7 9,7 10,8
説明
- 与える座標は、x_1 = 3、x_2 = 10、y_1 = です。 3、y_2 = 8。したがって、ステップではまず dx = x_2 - x_1 を 10 - 3 = 7 として計算し、dy を y_2 - y_1 8 - 3 = 5 として計算します。 次に、dy が dx より小さいかどうかを確認します。ここで d を 5 - (7 / 2) = 2 として計算します。最初の点は x_1 と y_1 です。印刷してください。ここで、x_1 入力: int x_1 = 2、int y_1 = 2、int x_2 = 3、int y_2 = 4出力: 行から生成セグメント アルゴリズムによって取得される中点は次のとおりです: 2,2 3,3 3,4
説明:
指定された座標は、x_1 = 2、x_2 = 2、y_1 = 3、y_2 = です。 4.中点セグメント生成アルゴリズムを適用することにより、すべての中点ピクセルが出力として計算されます。次のプログラムで使用されるメソッドは次のとおりです。
入力整数点は int x_1、int y_1、int x_2、int y_2 です。関数 Mid_Point(x_1, y_1, x_2, y_2) を呼び出して線分を生成します。
関数内部 Mid_Point(x_1, y_1, x_2, y_2)- dx を x_2 - x_1 として計算し、dy を y_2 - y_1 として計算します
-
dy が dx 以下であるかどうかを確認し、d を dy - (dx / 2) に設定し、first_pt を x_1 に設定し、second_pt を y_1 に設定します
- first_pt と Second_pt を出力します。
- while ループを開始します。first_pt が x_2 より小さい場合、first_pt を 1 増やし、d が 0 より小さいかどうかを確認し、d を d dy に設定します。それ以外の場合は、d を d に設定します ( dy - dx) を計算し、seced_pt を 1 ずつ増やします。 first_pt と Second_pt を出力します。
- それ以外の場合、dx が dy より小さい場合は、d を dx - (dy/2) に設定し、first_pt を x_1 に設定し、second_pt を y_1 に設定して、first_pt と Second_pt を出力します。
- while ループを開始します。 Second_pt が y_2 未満の場合、ループ内で Second_pt をインクリメントします。 Second_pt は 1 ずつ増加します。 d が 0 未満であることを確認し、d を d dx に設定します。それ以外の場合は、d を d (dx - dy) に設定し、first_pt を 1 ずつ増やします。
- first_pt と Second_pt を出力します。
- 例出力
#include<bits/stdc++.h> using namespace std; void Mid_Point(int x_1, int y_1, int x_2, int y_2){ int dx = x_2 - x_1; int dy = y_2 - y_1; if(dy <= dx){ int d = dy - (dx / 2); int first_pt = x_1; int second_pt = y_1; cout<< first_pt << "," << second_pt << "\n"; while(first_pt < x_2){ first_pt++; if(d < 0){ d = d + dy; } else{ d = d + (dy - dx); second_pt++; } cout << first_pt << "," << second_pt << "\n"; } } else if(dx < dy){ int d = dx - (dy/2); int first_pt = x_1; int second_pt = y_1; cout << first_pt << "," << second_pt << "\n"; while(second_pt < y_2){ second_pt++; if(d < 0){ d = d + dx; } else{ d += (dx - dy); first_pt++; } cout << first_pt << "," << second_pt << "\n"; } } } int main(){ int x_1 = 3; int y_1 = 3; int x_2 = 10; int y_2 = 8; cout<<"Mid-Points through Line Generation Algorithm are: "; Mid_Point(x_1, y_1, x_2, y_2); return 0; }
ログイン後にコピー
Mid-Points through Line Generation Algorithm are: 3,3 4,4 5,5 6,5 7,6 8,7 9,7 10,8
以上が中点ライン生成アルゴリズムの C++ 実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

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

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

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

ホットトピック









C言語データ構造:ツリーとグラフのデータ表現は、ノードからなる階層データ構造です。各ノードには、データ要素と子ノードへのポインターが含まれています。バイナリツリーは特別なタイプの木です。各ノードには、最大2つの子ノードがあります。データは、structreenode {intdata; structreenode*left; structreenode*右;}を表します。操作は、ツリートラバーサルツリー(前向き、順序、および後期)を作成します。検索ツリー挿入ノード削除ノードグラフは、要素が頂点であるデータ構造のコレクションであり、近隣を表す右または未照明のデータを持つエッジを介して接続できます。

ファイルの操作の問題に関する真実:ファイルの開きが失敗しました:不十分な権限、間違ったパス、およびファイルが占有されます。データの書き込みが失敗しました:バッファーがいっぱいで、ファイルは書き込みできず、ディスクスペースが不十分です。その他のFAQ:遅いファイルトラバーサル、誤ったテキストファイルエンコード、およびバイナリファイルの読み取りエラー。

記事では、移動セマンティクス、完璧な転送、リソース管理のためのcでのr値参照の効果的な使用について説明し、ベストプラクティスとパフォーマンスの改善を強調しています。(159文字)

C 20の範囲は、表現力、複合性、効率を伴うデータ操作を強化します。複雑な変換を簡素化し、既存のコードベースに統合して、パフォーマンスと保守性を向上させます。

C35の計算は、本質的に組み合わせ数学であり、5つの要素のうち3つから選択された組み合わせの数を表します。計算式はC53 = 5です! /(3! * 2!)。これは、ループで直接計算して効率を向上させ、オーバーフローを避けることができます。さらに、組み合わせの性質を理解し、効率的な計算方法をマスターすることは、確率統計、暗号化、アルゴリズム設計などの分野で多くの問題を解決するために重要です。

C言語関数は、コードモジュール化とプログラム構築の基礎です。それらは、宣言(関数ヘッダー)と定義(関数体)で構成されています。 C言語は値を使用してパラメーターをデフォルトで渡しますが、外部変数はアドレスパスを使用して変更することもできます。関数は返品値を持つか、または持たない場合があり、返品値のタイプは宣言と一致する必要があります。機能の命名は、ラクダを使用するか、命名法を強調して、明確で理解しやすい必要があります。単一の責任の原則に従い、機能をシンプルに保ち、メンテナビリティと読みやすさを向上させます。

この記事では、Cでの動的発送、そのパフォーマンスコスト、および最適化戦略について説明します。動的ディスパッチがパフォーマンスに影響を与え、静的ディスパッチと比較するシナリオを強調し、パフォーマンスとパフォーマンスのトレードオフを強調します

この記事では、不必要なコピーを回避することにより、パフォーマンスを向上させるために、CのMove Semanticsを使用することについて説明します。 STD :: MOVEを使用して、移動コンストラクターと割り当てオペレーターの実装をカバーし、効果的なAPPLの重要なシナリオと落とし穴を識別します
