Microsoft PowerPoint - 13.ppt [互換モード]

Similar documents
Microsoft PowerPoint - 12.ppt [互換モード]

Microsoft PowerPoint - 12.ppt [互換モード]

Microsoft PowerPoint - 11.ppt [互換モード]

Microsoft PowerPoint - 10.ppt [互換モード]

演算増幅器

Microsoft PowerPoint - 計算機言語 第7回.ppt

C 資料 電脳梁山泊烏賊塾 構造体 C++ の構造体 初めに 此処では Visual Studio 2017 を起動し 新しいプロジェクトで Visual C++ の Windows デスクトップを選択し Windows コンソールアプリケーションを作成する 定義と変数宣言 C++ に

memo

バイオプログラミング第 1 榊原康文 佐藤健吾 慶應義塾大学理工学部生命情報学科

プログラミング基礎

Microsoft PowerPoint - handout07.ppt [互換モード]

(2) 構造体変数の宣言 文法は次のとおり. struct 構造体タグ名構造体変数名 ; (1) と (2) は同時に行える. struct 構造体タグ名 { データ型変数 1; データ型変数 2;... 構造体変数名 ; 例 : struct STUDENT{ stdata; int id; do

演習課題No12

Microsoft PowerPoint - CproNt02.ppt [互換モード]

関数の動作 / printhw(); 7 printf(" n"); printhw(); printf("############ n"); 4 printhw(); 5 関数の作り方 ( 関数名 ) 戻り値 ( 後述 ) void である. 関数名 (

Microsoft PowerPoint - lec10.ppt

02: 変数と標準入出力

プログラミング基礎

Microsoft PowerPoint - 2.ppt [互換モード]

02: 変数と標準入出力

PowerPoint プレゼンテーション

PowerPoint プレゼンテーション

Microsoft Word - Cプログラミング演習(12)

/*Source.cpp*/ #include<stdio.h> //printf はここでインクルードして初めて使えるようになる // ここで関数 average を定義 3 つの整数の平均値を返す double 型の関数です double average(int a,int b,int c){

Prog1_15th

Microsoft PowerPoint - prog08.ppt

プログラミング実習I

C 言語第 7 回 掛け算 (multiply number) ìz1 = x1 + iy1 í îz = x + iy 割り算 (devide number) ( )( ) ( ) Þ z z = x + iy x + iy = x x - y y + i y x + x y

Microsoft PowerPoint - 11.pptx

Microsoft PowerPoint - class2-OperatorOverLoad.pptx

memo

Microsoft Word - no13.docx

基礎プログラミング2015

プログラミング基礎

PowerPoint Presentation

PowerPoint Presentation

PowerPoint Presentation

Microsoft PowerPoint - 13th.ppt [互換モード]

講習No.12

C プログラミング演習 1( 再 ) 2 講義では C プログラミングの基本を学び 演習では やや実践的なプログラミングを通して学ぶ

memo

Taro-ポインタ変数Ⅰ(公開版).j

char int float double の変数型はそれぞれ 文字あるいは小さな整数 整数 実数 より精度の高い ( 数値のより大きい より小さい ) 実数 を扱う時に用いる 備考 : 基本型の説明に示した 浮動小数点 とは数値を指数表現で表す方法である 例えば は指数表現で 3 書く

PowerPoint プレゼンテーション

DVIOUT

kiso2-09.key

PowerPoint プレゼンテーション

Microsoft PowerPoint - 4.ppt [互換モード]

Microsoft PowerPoint - 3.ppt [互換モード]

Microsoft PowerPoint ppt

Prog1_6th

2006年10月5日(木)実施

JavaプログラミングⅠ

PowerPoint プレゼンテーション

関数の中で宣言された変数の有効範囲はその関数の中だけです さっきの rectangle _s で宣言されている変数 s は他の関数では使用できません ( 別の関数で同じ名前の変数を宣言することはできますが 全く別の変数として扱われます このように ある関数の中で宣言されている変数のことをその関数の

配列, 関数, 構造体

Prog1_12th

ゲームエンジンの構成要素

Microsoft PowerPoint pptx

gengo1-11

Microsoft Word - no11.docx

Slide 1

<4D F736F F D2091E63589F182628CBE8CEA8D758DC08E9197BF2E646F6378>

cp-7. 配列

Microsoft PowerPoint - C言語の復習(配布用).ppt [互換モード]

講習No.12

Taro-リストⅠ(公開版).jtd

Microsoft Word - Cプログラミング演習(7)

RX ファミリ用 C/C++ コンパイラ V.1.00 Release 02 ご使用上のお願い RX ファミリ用 C/C++ コンパイラの使用上の注意事項 4 件を連絡します #pragma option 使用時の 1 または 2 バイトの整数型の関数戻り値に関する注意事項 (RXC#012) 共用

6 関数 6-1 関数とは少し長いプログラムを作るようになると 同じ処理を何度も行う場面が出てくる そのたびに処 理を書いていたのでは明らかに無駄であるし プログラム全体の見通しも悪くなる そこで登場す るのが 関数 である 関数を使うことを 関数を呼び出す ともいう どのように使うのか 実際に見て

プログラミング方法論 II 第 14,15 回 ( 担当 : 鈴木伸夫 ) 問題 17. x 座標と y 座標をメンバに持つ構造体 Point を作成せよ 但し座標 は double 型とする typedef struct{ (a) x; (b) y; } Point; 問題 18. 問題 17 の

Microsoft Word - no12.doc

Microsoft PowerPoint - prog04.ppt

Microsoft PowerPoint - 説明2_演算と型(C_guide2)【2015新教材対応確認済み】.pptx

講習No.10

Microsoft Word - Training10_プリプロセッサ.docx

gengo1-10

Microsoft Word - no15.docx

第3回 配列とリスト

プログラミング実習I

#include<math.h> 数学関係の関数群で sin() cos() tan() などの三角関数や累乗の pow() 平方根を求める sqrt() 対数 log() などがあります #include<string.h> 文字列を扱う関数群 コイツもまた後日に 4. 自作関数 実は 関数は自分

第2回講義:まとめ

Microsoft PowerPoint - exp2-02_intro.ppt [互換モード]

Microsoft Word - 3new.doc

Microsoft Word - no02.doc

Prog1_10th

情報処理Ⅰ演習

基礎プログラミング2015

プログラミング基礎

SuperH RISC engineファミリ用 C/C++コンパイラパッケージ V.7~V.9 ご使用上のお願い

スライド 1

問 2 ( 型変換 ) 次のプログラムを実行しても正しい結果が得られない 何が間違いかを指摘し 正しく修正せよ ただし int サイズが 2 バイト long サイズが 4 バイトの処理系での演算を仮定する #include <stdio.h> int main( void ) { int a =

Microsoft PowerPoint - 12Chap16.ppt

Microsoft Word - no204.docx

Microsoft PowerPoint - kougi8.ppt

Microsoft PowerPoint - prog06.ppt

Microsoft PowerPoint - kougi7.ppt

PowerPoint プレゼンテーション

関数 C 言語は関数の言語 関数とは 関数の定義 : f(x) = x * x ; 使うときは : y = f(x) 戻り値 引数

<4D F736F F D20438CBE8CEA8D758DC03389F0939A82C282AB2E646F63>

Transcription:

第 13 回構造体 1

今回の目標 構造体を理解する 構造体の定義の仕方を理解する 構造体型を理解する 構造体型の変数 引数 戻り値を理解する 複素数同士を足し算する関数を作成し その関数を利用するプログラムを作成する 2

複素数の足し算 複素数は実部と虚部の2つの実数で 表現される z = a+ bi z = a + bi z = a + b i 2 つの複素数 1 1 1 と 2 2 2 の和 z = a + bi は 次式で与えられる 3 3 3 z = z + z 3 1 2 = ( a + a ) + ( b + b ) i 1 2 1 2 3

構造体 構造体とは いくつかのデータを 1つのまとまりとして扱うデータ型 プログラマが定義してから使う 構造体型の変数 定数 引数 戻り値等が利用できるようになる ( 他の言語ではレコード型と呼ぶこともある ) 一まとまりのデータ例 複素数 : 実部と虚部点 :x 座標 y 座標 2 次元ベクトル :x 成分 y 成分 名刺 : 所属 名前 連絡先日付 : 年 月 日 曜日 曜本 : 題名 著者 ISBN 4

構造体型の定義 ( 構造体テンプレートの宣言 ) 構造体を構成する要素を宣言メンバといいます struct 構造体タグ名 { これを型 1 メンバ名 1; 構造体テンプレートという 型 2 メンバ名 2; 型 3 メンバ名 3; int,double,char : や }; int *,double *,char* や例既に定義した構造体型等 struct complex { double real; double imag; }; 関数の記述と似ているがセミコロンを忘れずに 5

構造体型の変数の用意の仕方 ( 構造体型の変数宣言 ) 宣言 struct 構造体タグ名変数名 ; 例 ここに空白がある struct complex z; 参考 int i; double x; この2つで 一つの型を表わしているので注意すること 6

構造体のイメージ char int double 構造体テンプレート struct complex { double real; double imag; }; 既存の型雛形の作成 struct complex 型の雛形 セミコロンを忘れずに 7

構造体型の変数宣言 struct complex z1; struct complex z2; struct complex 型の雛形 雛形を用いて プレスする z1 struct complex 型の変数 z2 struct complex 型の変数 8

構造体のイメージ 2 char int double struct card { char int double }; initial; age; weight; 雛形の作成 struct card 型の雛形 いろいろな型のデータを一まとまりであつかうときには 構造体はとくに便利 9

構造体型の配列宣言 #define MAXCARD 3 struct card x[maxcard]; struct card 型の変数 x[0] x[1] x[2] 10

構造体のメンバの参照 struct 型の変数のメンバの参照の仕方 書式 変数名. メンバ名 例 ドット ( 演算子の一つ ) これらを メンバ名を定義している型の変数として扱える z1.real これはdouble 型の変数である x[0].inital これは char 型の変数である 11

参照のイメージ struct t complex z1; struct complex 型の雛形 struct complex 型の変数 real imag real imag z1 real z1.real imag z1.imag 12

構造体とメモリ c1 struct card c1; struct card c2 } } } c1.initial } c1.age c1.weight c2 struct card 型の変数 13

構造体へのポインタ struct card c1; struct card *p; 0x00ffbb00 (*p) c1 struct card * 型の変数 } } } (*p).initial p->initial iti (*p).age p->age } (*p).weight p->initial struct card 型の変数 p c1 14

演算子. の結合力演算子. の結合力は他のどの演算子よりも強い.( ドット演算子 ) x[0].age++; > は ++ -- (x[0].age)++; > * & の意味 struct card * p; のとき *p.age; は *(p.age); の意味になってしまう 両方間違い ( メンバ age は ポインタではない ) (*p).age; 型的には これが正しい ( ソースの可読性の向上のため ) 他の演算子と一緒に使うときには 括弧を用いて意図を明確にすること 15

構造体と代入演算子 1 ( 構造体への値の入れ方 1) 全てのメンバに値を代入する struct complex z1; (z1.real)=1.0; (z1.imag)=2.0; 間違い例 z1=1.0+2.0i; z1=(1.0,2.0); 複素数だからってこんなふうにはかけない ベクトル風にもかけない 16

イメージ struct complex z1; real imag z1 (z1.real)=1.0; 1.0; (z1.imag)=2.0; real z1.real imag z1.imag real imag z1 17

構造体と代入演算子 2 ( 構造体への値の入れ方 2) 同じ型の構造体同士で代入する struct complex z1; struct complex z2; (z1.real) real)=1.0; (z1.imag)=2.0; z2=z1; 18

イメージ struct complex z1; struct complex z2; 構造体の値設定 (z1.real)=1.0; (z1.imag)=2.0; ( 各メンバへの代入 z2 real imag real imag z1 構造体の代入 z2=z1; z2 real imag real imag z1 19

練習 /*test_struct.c 構造体実験コメント省略 */ #include <stdio.h> struct complex { double real; double imag; }; /* 次に続く */ 20

int { main() struct complex z1; struct complex z2; printf(" メンバの読み込み n"); printf("z1= (real?) + (imag?)i "); scanf( %lf %lf",&(z1.real),&(z1.imag)); printf(" 読み込み後 n"); printf("z1=%4.2f+(%4.2f)i n", ( z1.real,z1.imag); printf("z2=%4.2f+(%4.2f)i n", z2.real,z2.imag); 2 /* 続く */ 21

/* 続き */ printf( z2=z1 実行中 n"); z2=z1; printf(" 代入後 n"); pritnf("z1=%4.2f +(%4.2f)i n", z1.real,z1.imag); pritnf("z2=%4.2f +(%4.2f)i n", z2.real,z2.imag); } return 0; 22

複素数の和を求めるプログラム /* 作成日 :yyyy/mm/dd 作成者 : 本荘太郎学籍番号 :B0zB0xx ソースファイル :pluscomp.c 実行ファイル :pluscomp 説明 : 構造体を用いて 2つの複素数の和を求めるプログラム 入力 : 標準入力から 2つの複素数 z1とz2を入力 z1 の ( 実部 虚部 ) z2 の ( 実部 虚部 ) の順で4つの実数を入力する 出力 : 標準出力にその2つの複素数の和を出力する */ /* 続く */ 23

/* 続き */ #include <stdio.h> /* 構造体テンプレート定義 */ Struct complex /* 複素数を表わす構造体 */ { double real; /* 実部 */ double imag; /* 虚部 */ }; /* プロトタイプ宣言 */ struct complex scan_complex(void); /* 標準入力から複素数を読み込む関数 */ void print_complex(struct complex z); /* 標準出力へ複素数を出力する関数 */ struct complex plus_complex(struct complex z1, struct complex z2); /*2つの複素数の和を求める関数*/ /* 続く */ 24

/*main 関数開始 */ int main() { /* ローカル変数宣言 */ struct complex z1; /* 複素数 1*/ struct complex z2; /* 複素数 2*/ struct complex sum; /* 複素数の和を蓄える変数 */ /* 入力処理 */ z1=scan_complex(); complex(); z2=scan_complex(); /* 計算処理 */ sum=plus_complex(z1,z2); /*main 関数続く */ 25

/* 続き main 関数 */ /* 出力処理 */ print_complex(z1); printf( + ); print_complex(z2); printf( = ); print_complex(sum); printf( n ); /* 正常終了 */ return 0; } /*main 関数終了 */ /* 続く */ 26

/* 続き 関数 scan_complexの定義 */ /* 標準入力から複素数を受け取る関数 実部 虚部の順にdouble 値を受け取る 仮引数 : なし (void) 戻り値 : 読み込まれた複素数 */ struct complex scan_complex(void) { /* ローカル変数宣言 */ struct complex z;/* 読み込まれる複素数 */ /* 入力処理 */ scanf( %lf,&(z.real)); /* 実部 */ scanf( %lf,&(z.imag)); /* 虚部 */ return z; } /* 関数 scan_complexの定義終了 */ /* 続く */ 27

/* 続き 関数 scan_complexcomplex の定義 */ /* 複素数を ( 実部 +( 虚部 )i) の形式で標準出力に出力する関数 仮引数 z: 表示される複素数戻り値 : なし (void) */ void print_complex(struct complex z) { /* 出力処理 */ printf( ( %4.1f +(%4.1f)i ),z.real,z.imag); return; } /* 関数 print_complexの定義終了 */ /* 続く */ 28

/*2つの複素数の和を求める関数仮引数 z1,z2:2つの複素数 戻り値 :2つの複素数の和(z1+z2) */ struct complex plus_ complex(struct complex z1, struct complex z2) { /* ローカル変数宣言 */ struct complex sum;/*2つの複素数の和を蓄える */ /* 計算処理 */ (sum.real)=(z1.real)+(z2.real); real)+(z2 real); /* 実部の計算 */ (sum.imag)=(z1.imag)+(z2.imag);/* 虚部の計算 */ return sum; } /* 関数 plus_complexの終了 */ /* プログラムpluscomp.c の終了 */ 29

実行結果 $./pluscomplex 2つの複素数 z1,z2 を入力して下さい ( 4.0+( 6.0)i)=( 1.0+( 2.0)i)+( 3.0+( 4.0)i) $ 30