検索
ホームページバックエンド開発C++中点ライン生成アルゴリズムの C++ 実装

中点ライン生成アルゴリズムの C++ 実装

Sep 09, 2023 pm 07:49 PM
生成アルゴリズムcの実装中点線

中点ライン生成アルゴリズムの C++ 実装

#直線は 2 つの点を結びます。グラフィックの基本要素です。線を引くには 2 つの点が必要で、画面上のこれら 2 つの点の間に線を描きます。グラフィックスではこれらの点をピクセルと呼び、各ピクセルは整数の座標に関連付けられます。整数座標を (x1, y1) および (x2, y2) の形式で指定します。ここで、x1 For では 3 つの異なるアルゴリズムが使用されています。画面上でライン生成を実行する場合、これらは -

    #DDA アルゴリズム
  • #ブレゼンハム ライン生成
  • #中点アルゴリズム

  • #中点アルゴリズム

    #中点を使用して線を描く手順 点線アルゴリズムは、-

## です。 #Use 現在の測位点は中点、つまり東(Xp 1, Yp)と北東(Xp 1, Yp) 1)を中点(Xp 1, Yp 1/2)として計算します。

    これで、中点によって画面上の次の座標の位置が決まります。つまり、
  • 中点が線の上にある場合、次の座標が決まります。東になります。
  • p>

      中点が線より下にある場合、次の座標は北東になります。
    • #さまざまな入出力シナリオを見てみましょう-

    • Input
    - int x_1 = 3, int y_1 = 3、int x_2 = 10、int y_2 = 8

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 サイトの他の関連記事を参照してください。

声明
この記事はtutorialspointで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Cの寿命:現在の状態を調べますCの寿命:現在の状態を調べますApr 26, 2025 am 12:02 AM

Cは、効率的で柔軟で強力な性質のため、最新のプログラミングで依然として重要です。 1)Cシステムプログラミング、ゲーム開発、組み込みシステムに適したオブジェクト指向プログラミングをサポートします。 2)多型はCのハイライトであり、基本クラスのポインターまたはコードの柔軟性とスケーラビリティを強化するための参照を介して派生クラスのメソッドを呼び出すことができます。

C#対Cパフォーマンス:ベンチマークと考慮事項C#対Cパフォーマンス:ベンチマークと考慮事項Apr 25, 2025 am 12:25 AM

C#とCのパフォーマンスの違いは、主に実行速度とリソース管理に反映されます。1)Cは通常、ハードウェアに近く、ガベージコレクションなどの追加のオーバーヘッドがないため、数値計算と文字列操作でより良いパフォーマンスを発揮します。 2)C#はマルチスレッドプログラミングでより簡潔ですが、そのパフォーマンスはCよりもわずかに劣っています。 3)プロジェクトの要件とチームテクノロジースタックに基づいて、どの言語を選択するかを決定する必要があります。

C:それは死にかけていますか、それとも単に進化していますか?C:それは死にかけていますか、それとも単に進化していますか?Apr 24, 2025 am 12:13 AM

c isnotdying; it'sevolving.1)c relelevantdueToitsversitileSileSixivisityinperformance-criticalApplications.2)thelanguageSlikeModulesandCoroutoUtoimveUsablive.3)despiteChallen

C現代の世界:アプリケーションと産業C現代の世界:アプリケーションと産業Apr 23, 2025 am 12:10 AM

Cは、現代世界で広く使用され、重要です。 1)ゲーム開発において、Cは、非現実的や統一など、その高性能と多型に広く使用されています。 2)金融取引システムでは、Cの低レイテンシと高スループットが最初の選択となり、高周波取引とリアルタイムのデータ分析に適しています。

C XMLライブラリ:オプションの比較と対照C XMLライブラリ:オプションの比較と対照Apr 22, 2025 am 12:05 AM

C:tinyxml-2、pugixml、xerces-c、およびrapidxmlには、一般的に使用される4つのXMLライブラリがあります。 1.TinyXML-2は、リソースが限られている環境、軽量ではあるが機能が限られていることに適しています。 2。PUGIXMLは高速で、複雑なXML構造に適したXPathクエリをサポートしています。 3.Xerces-Cは強力で、DOMとSAXの解像度をサポートし、複雑な処理に適しています。 4。RapidXMLはパフォーマンスと分割に非常に高速に焦点を当てていますが、XPathクエリをサポートしていません。

CおよびXML:関係とサポートの調査CおよびXML:関係とサポートの調査Apr 21, 2025 am 12:02 AM

Cは、サードパーティライブラリ(TinyXML、PUGIXML、XERCES-Cなど)を介してXMLと相互作用します。 1)ライブラリを使用してXMLファイルを解析し、それらをC処理可能なデータ構造に変換します。 2)XMLを生成するときは、Cデータ構造をXML形式に変換します。 3)実際のアプリケーションでは、XMLが構成ファイルとデータ交換に使用されることがよくあり、開発効率を向上させます。

C#対C:重要な違​​いと類似点を理解するC#対C:重要な違​​いと類似点を理解するApr 20, 2025 am 12:03 AM

C#とCの主な違いは、構文、パフォーマンス、アプリケーションシナリオです。 1)C#構文はより簡潔で、ガベージコレクションをサポートし、.NETフレームワーク開発に適しています。 2)Cはパフォーマンスが高く、手動メモリ管理が必要であり、システムプログラミングとゲーム開発でよく使用されます。

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

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

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

メモ帳++7.3.1

メモ帳++7.3.1

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

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。