0) printf(" + %f i\n", c.i); } else if (c.i < 0) printf(" - %f i\n", -c.i); complex Add(complex a, complex b) { complex c; c.r = a.r + b.r; c.i = a.i + b.i; return c; } complex Subtract(complex a, complex b) c.r = a.r - b.r; c.i = a.i - b.i; complex Multiply(complex a, complex b) c.r = a.r * b.r - a.i * b.i; c.i = a.r * b.i + a.i * b.r; complex Divide(complex a, complex b) double b2 = SqrComp(b); c.r = (a.r * b.r + a.i * b.i)/b2; c.i = -(a.r * b.i - a.i * b.r)/b2; 虚部が正値の場合は,      i          虚部が負値の場合は,      i          のようにcomplex型構造体変数cの内容を表示する. ヒント: 複素数x = a + bi, y = c + diとすると,|x|2=a2+b2であり,またx+y = (a+c) + (b+d)iであり,その他の演算も通常の複素数の演算にしたがって処理されなければならない. なお,商は複雑で,x/y = (ac+bd)/|y|2 - (ad-bc)/|y|2 i となる."> 0) printf(" + %f i\n", c.i); } else if (c.i < 0) printf(" - %f i\n", -c.i); complex Add(complex a, complex b) { complex c; c.r = a.r + b.r; c.i = a.i + b.i; return c; } complex Subtract(complex a, complex b) c.r = a.r - b.r; c.i = a.i - b.i; complex Multiply(complex a, complex b) c.r = a.r * b.r - a.i * b.i; c.i = a.r * b.i + a.i * b.r; complex Divide(complex a, complex b) double b2 = SqrComp(b); c.r = (a.r * b.r + a.i * b.i)/b2; c.i = -(a.r * b.i - a.i * b.r)/b2; 虚部が正値の場合は,      i          虚部が負値の場合は,      i          のようにcomplex型構造体変数cの内容を表示する. ヒント: 複素数x = a + bi, y = c + diとすると,|x|2=a2+b2であり,またx+y = (a+c) + (b+d)iであり,その他の演算も通常の複素数の演算にしたがって処理されなければならない. なお,商は複雑で,x/y = (ac+bd)/|y|2 - (ad-bc)/|y|2 i となる.">

Presentation is loading. Please wait.

Presentation is loading. Please wait.

次ページに関数の解答例 課題12-1 (問題と解答) 複素数xとして, 実部を入力してください.10 虚部を入力してください.20

Similar presentations


Presentation on theme: "次ページに関数の解答例 課題12-1 (問題と解答) 複素数xとして, 実部を入力してください.10 虚部を入力してください.20"— Presentation transcript:

1 次ページに関数の解答例 課題12-1 (問題と解答) 複素数xとして, 実部を入力してください.10 虚部を入力してください.20
課題12-1 (問題と解答) #include <stdio.h> struct complex { float r; // 実部(英語でreal) float i; // 虚部(英語でimaginary) }; complex InputComp(void) complex c; printf("実部を入力してください."); scanf("%f", &c.r); printf("虚部を入力してください."); scanf("%f", &c.i); return(c); } float SqrComp(complex c) return (c.r*c.r + c.i*c.i); main() { complex x, y, z; printf("複素数xとして,\n"); x = InputComp(); printf("複素数yとして,\n"); y = InputComp(); printf("xの絶対値の2乗は%f\n", SqrComp(x)); printf("yの絶対値の2乗は%f\n", SqrComp(y)); printf("x + y = "); z = Add(x, y); // 長く書くとこんなかんじ PrintComp(z); printf("x - y = "); PrintComp(Subtract(x, y));// 短く書くとこんなかんじ printf("x * y = "); PrintComp(Multiply(x, y)); printf("x / y = "); PrintComp(Divide(x, y)); } 複素数xとして, 実部を入力してください.10 虚部を入力してください.20 複素数yとして, 実部を入力してください.-3.5 虚部を入力してください.10.1 xの絶対値の2乗は yの絶対値の2乗は x + y = i x - y = i x * y = i x / y = i 次ページに関数の解答例

2 課題12-1 (続き) void PrintComp(complex c) { printf("%f", c.r);
課題12-1 (続き) void PrintComp(complex c) { printf("%f", c.r); if (c.i > 0) printf(" + %f i\n", c.i); } else if (c.i < 0) printf(" - %f i\n", -c.i); complex Add(complex a, complex b) { complex c; c.r = a.r + b.r; c.i = a.i + b.i; return c; } complex Subtract(complex a, complex b) c.r = a.r - b.r; c.i = a.i - b.i; complex Multiply(complex a, complex b) c.r = a.r * b.r - a.i * b.i; c.i = a.r * b.i + a.i * b.r; complex Divide(complex a, complex b) double b2 = SqrComp(b); c.r = (a.r * b.r + a.i * b.i)/b2; c.i = -(a.r * b.i - a.i * b.r)/b2; 虚部が正値の場合は,      i          虚部が負値の場合は,      i          のようにcomplex型構造体変数cの内容を表示する. ヒント: 複素数x = a + bi, y = c + diとすると,|x|2=a2+b2であり,またx+y = (a+c) + (b+d)iであり,その他の演算も通常の複素数の演算にしたがって処理されなければならない. なお,商は複雑で,x/y = (ac+bd)/|y|2 - (ad-bc)/|y|2 i となる.

3 課題12-2 (課題の関数のみ記載) complex AverageComp(complex c[], int n) {
課題12-2 (課題の関数のみ記載) complex AverageComp(complex c[], int n) { // 各自でプログラム int i; complex sum, result; sum.r = 0; sum.i = 0; for (i = 0; i < n; i++) sum = Add(sum, c[i]); } result.r = sum.r/n; result.i = sum.i/n; return result; double AverageSqrComp(complex c[], int n) double ss = 0; ss = ss + SqrComp(c[i]); return ss/n;

4 課題12-3 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h>
//一人分のデータを表す構造体 struct PersonData { int ID; //学籍番号 char name[11]; //名前(10文字まで) int point[4]; //4回分の得点 }; //一人分のデータを入力する関数.構造体変数を返却する PersonData InputData(void) PersonData ps; int i; printf("番号(4桁まで)?: "); scanf("%d", &ps.ID); if (ps.ID == 0) //もし番号0だったら入力終了 return ps; } printf("名前(10文字まで)?: "); scanf("%s", ps.name); for (i = 0; i < 4; i++) printf("第%d回の得点(10点満点)?: ", i + 1); scanf("%d", &ps.point[i]); //構造体変数aの内容を表示する void PrintPerson(PersonData a) { int i; printf("%4d %-10s :", a.ID, a.name); for (i = 0; i < 4; i++) printf("%3d", a.point[i]); } //構造体変数bの得点データの平均値を返却する float Average(PersonData b) float sum = 0; sum = sum + b.point[i]; return sum/4;

5 課題12-3 (続き) 20名までのデータを入力してください.番号0の入力で終了します 番号(4桁まで)?: 135
課題12-3 (続き) int main(void) { PersonData data[20]; //最大20名を処理する int n, i; printf("20名までのデータを入力してください.番号0の入力で終了します\n"); for (n = 0; n < 20; n++) //最大20名分まで入力 data[n] = InputData(); if (data[n].ID == 0) //番号が0だったら入力終了 break; } printf("\n"); printf("番号 名前 得点 平均点\n"); printf(" \n"); for (i = 0; i < n; i++) //入力された人数は変数nに残っている PrintPerson(data[i]); //一人分のデータを表示 printf(" : %4.1f\n", Average(data[i])); //平均点を表示 20名までのデータを入力してください.番号0の入力で終了します 番号(4桁まで)?: 135 名前(10文字まで)?: Tokugawa 第1回の得点(10点満点)?: 2 第2回の得点(10点満点)?: 3 第3回の得点(10点満点)?: 9 第4回の得点(10点満点)?: 10 番号(4桁まで)?: 288 名前(10文字まで)?: Oda 第1回の得点(10点満点)?: 10 第2回の得点(10点満点)?: 9 第3回の得点(10点満点)?: 8 第4回の得点(10点満点)?: 0 番号(4桁まで)?: 512 名前(10文字まで)?: Toyotomi 第2回の得点(10点満点)?: 10 第3回の得点(10点満点)?: 10 第4回の得点(10点満点)?: 5 番号(4桁まで)?: 0 番号 名前 得点 平均点 135 Tokugawa : : 6.0 288 Oda : : 6.8 512 Toyotomi : : 6.8 続行するには何かキーを押してください . . .


Download ppt "次ページに関数の解答例 課題12-1 (問題と解答) 複素数xとして, 実部を入力してください.10 虚部を入力してください.20"

Similar presentations


Ads by Google