モーダルを閉じる工作HardwareHub ロゴ画像

工作HardwareHubは、ロボット工作や電子工作に関する情報やモノが行き交うコミュニティサイトです。さらに詳しく

利用規約プライバシーポリシー に同意したうえでログインしてください。

工作HardwareHub ロゴ画像 (Laptop端末利用時)
工作HardwareHub ロゴ画像 (Mobile端末利用時)

STL/複素数 (C++をもう一度)

モーダルを閉じる

ステッカーを選択してください

モーダルを閉じる

お支払い内容をご確認ください

購入商品
」ステッカーの表示権
メッセージ
料金
(税込)
決済方法
GooglePayマーク
決済プラットフォーム
確認事項

利用規約をご確認のうえお支払いください

※カード情報はGoogleアカウント内に保存されます。本サイトやStripeには保存されません

※記事の執筆者は購入者のユーザー名を知ることができます

※購入後のキャンセルはできません

作成日作成日
2014/12/28
最終更新最終更新
2017/05/04
記事区分記事区分
一般公開

目次

    低レイヤーのプログラミングとOS開発が趣味。C言語を使っています。

    0
    ステッカーを贈るとは?

    サンプルコード

    #include <iostream>
    #include <complex>
    using namespace std;
    
    typedef complex<double> P;
    #define X real()
    #define Y imag()
    
    // 内積 |a||b|cos(theta)
    double dot(P a, P b) {
        return a.X * b.X + a.Y * b.Y;
    }
    
    // 外積 |a||b|sin(theta)
    double cross(P a, P b) {
        return a.X * b.Y - a.Y * b.X;
    }
    
    int main() {
        // 複素数 (座標)
        //           (1, 1)
        //           |
        // (0,0) --- (1, 0)
        P p1(0, 0);
        P p2(1, 1);
        P p3(1, 0);
    
        // 線分の長さ
        cout << abs(p1 - p2) << endl; //=> 1.414...
    
        // 内積
        cout << dot(p2 - p1, p3 - p1) << endl; //=> 1
    
        // 外積 (平行四辺形の面積)
        cout << abs(cross(p2 - p1, p3 - p1)) << endl; //=> 1
    
        return 0;
    }
    
    0
    詳細設定を開く/閉じる
    アカウント プロフィール画像 (本文下)

    低レイヤーのプログラミングとOS開発が趣味。C言語を使っています。

    記事の執筆者にステッカーを贈る

    有益な情報に対するお礼として、またはコメント欄における質問への返答に対するお礼として、 記事の読者は、執筆者に有料のステッカーを贈ることができます。

    さらに詳しく →
    ステッカーを贈る コンセプト画像

    Feedbacks

    Feedbacks コンセプト画像

      ログインするとコメントを投稿できます。

      関連記事