C言語で複素数を扱うにはどうすればいいですか? 質問する

C言語で複素数を扱うにはどうすればいいですか? 質問する

C で複素数を扱うにはどうしたらいいですか?complex.hヘッダー ファイルがあることはわかりましたが、その使用方法に関する情報はあまりありません。実数部と虚数部に効率的にアクセスするにはどうすればいいですか? モジュールと位相を取得するためのネイティブ関数はありますか?

ベストアンサー1

このコードは役に立つでしょうし、かなりわかりやすいです:

#include <stdio.h>      /* Standard Library of Input and Output */
#include <complex.h>    /* Standard Library of Complex Numbers */

int main() {

    double complex z1 = 1.0 + 3.0 * I;
    double complex z2 = 1.0 - 4.0 * I;

    printf("Working with complex numbers:\n\v");

    printf("Starting values: Z1 = %.2f + %.2fi\tZ2 = %.2f %+.2fi\n", creal(z1), cimag(z1), creal(z2), cimag(z2));

    double complex sum = z1 + z2;
    printf("The sum: Z1 + Z2 = %.2f %+.2fi\n", creal(sum), cimag(sum));

    double complex difference = z1 - z2;
    printf("The difference: Z1 - Z2 = %.2f %+.2fi\n", creal(difference), cimag(difference));

    double complex product = z1 * z2;
    printf("The product: Z1 x Z2 = %.2f %+.2fi\n", creal(product), cimag(product));

    double complex quotient = z1 / z2;
    printf("The quotient: Z1 / Z2 = %.2f %+.2fi\n", creal(quotient), cimag(quotient));

    double complex conjugate = conj(z1);
    printf("The conjugate of Z1 = %.2f %+.2fi\n", creal(conjugate), cimag(conjugate));

    return 0;
}

  と:

creal(z1):実部を取得します( float の場合crealf(z1)、 long double の場合creall(z1)

cimag(z1):虚数部を取得します( float の場合cimagf(z1)、 long double の場合cimagl(z1)

複素数を扱うときに覚えておくべきもう 1 つの重要な点は、、、などの関数cos()exp()その複素形式 (例: 、、)sqrt()に置き換える必要があるということです。ccos()cexp()csqrt()

おすすめ記事