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

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

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

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

演算増幅器

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

演習課題No12

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

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

プログラミング基礎

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

memo

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

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

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

02: 変数と標準入出力

プログラミング基礎

Microsoft PowerPoint - class2-OperatorOverLoad.pptx

02: 変数と標準入出力

Microsoft PowerPoint - lec10.ppt

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

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 - CproNt02.ppt [互換モード]

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

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

PowerPoint プレゼンテーション

Microsoft PowerPoint - prog08.ppt

プログラミング実習I

kiso2-09.key

Microsoft Word - no13.docx

基礎プログラミング2015

Prog1_6th

PowerPoint プレゼンテーション

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

講習No.12

DVIOUT

Microsoft PowerPoint - 11.pptx

Microsoft PowerPoint ppt

memo

PowerPoint Presentation

Prog1_15th

2006年10月5日(木)実施

JavaプログラミングⅠ

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

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

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

memo

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

Microsoft Word - no11.docx

Prog1_12th

Microsoft Word - no12.doc

PowerPoint プレゼンテーション

PowerPoint Presentation

PowerPoint プレゼンテーション

Slide 1

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

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

cp-7. 配列

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

Microsoft PowerPoint pptx

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

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

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

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

PowerPoint Presentation

PowerPoint プレゼンテーション

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

Microsoft Word - no02.doc

配列, 関数, 構造体

gengo1-11

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

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

第3回 配列とリスト

Prog1_10th

講習No.12

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

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

Microsoft PowerPoint - prog04.ppt

情報処理Ⅰ演習

<4D F736F F D2091E63589F182628CBE8CEA8D758DC08E9197BF2E646F6378>

基礎プログラミング2015

プログラミング基礎

Microsoft PowerPoint - 12Chap16.ppt

Microsoft Word - no15.docx

(1) プログラムの開始場所はいつでも main( ) メソッドから始まる 順番に実行され add( a,b) が実行される これは メソッドを呼び出す ともいう (2)add( ) メソッドに実行が移る この際 add( ) メソッド呼び出し時の a と b の値がそれぞれ add( ) メソッド

Microsoft PowerPoint - kougi8.ppt

Microsoft PowerPoint - kougi7.ppt

講習No.10

Microsoft Word - no202.docx

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

8 / 0 1 i++ i 1 i-- i C !!! C 2

プログラミング実習I

画像ファイルを扱う これまでに学んだ条件分岐, 繰り返し, 配列, ファイル入出力を使って, 画像を扱うプログラムにチャレンジしてみよう

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

gengo1-10

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

Microsoft PowerPoint - class04.ppt

Microsoft Word - 3new.doc

7 ポインタ (P.61) ポインタを使うと, メモリ上のデータを直接操作することができる. 例えばデータの変更 やコピーなどが簡単にできる. また処理が高速になる. 7.1 ポインタの概念 変数を次のように宣言すると, int num; メモリにその領域が確保される. 仮にその開始のアドレスを 1

PowerPoint プレゼンテーション

Transcription:

第 12 回構造体 1

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

複素数の足し算 複素数は実部と虚部の2つの実数で 表現される 表現される z = a+ bi 2 つの複素数 z 1 = a 1+ bi 1 と z2 = a2 + b2i の和 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; : }; 例 struct complex { double real; double imag; }; メンバといいます これを構造体テンプレートという int,double,char や int *,double *,char* や既に定義した構造体型等 関数の記述と似ているがセミコロンを忘れずに 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

構造体とメモリ struct card c1; struct card c2; c1 } } } 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 (*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; (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", &(z1.real) ); scanf("%lf", &(z1.imag) ); printf(" 読み込み後 n"); printf("z1=%4.2f+(%4.2f)i n", z1.real, z1.imag); printf("z2=%4.2f+(%4.2f)i n", 2f+(%4 2f)i " z2.real, z2.imag); /* 続く */ 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 / 作成者 : 本荘太郎学籍番号 :B00B0xx ソースファイル :addcomp.cc 実行ファイル :addcomp 説明 : 構造体を用いて 2つの複素数の和を求めるプログラム 入力 : 標準入力から 2つの複素数 z1とz2を入力 z1の ( 実部 虚部 ) z2の ( 実部 虚部 ) の順 で 4 つの実数を入力する 出力 : 標準出力にその2つの複素数の和を出力する 和は複素数であり その実部と虚部は実数 23

/* 続き */ #include <stdio.h> /* 構造体テンプレート定義 */ struct complex /* 複素数を表わす構造体 */ { double real; /* 実部 */ double imag; /* 虚部 */ }; /* プロトタイプ宣言 */ struct complex scan_complex(); complex(); /* 標準入力から複素数を読み込む関数 */ void print_complex(struct complex z); /* 標準出力へ複素数を出力する関数 */ struct t complex add_complex (struct t 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 = add_complex (z1, z2); /*main 関数続く */ 25

/* 続き main 関数 */ /* 計算結果の出力 */ print_complex(z1); printf("+"); print_complex(z2); printf("="); print_complex(sum); printf(" n"); /* 正常終了 */ return 0; } /*main 関数終了 */ /* 続く */ 26

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

/* 続き */ /* 複素数を ( 実部 +( 虚部 )i ) の形式で標準出力に出力する関数 仮引数 z: 表示すべき複素数戻り値 : なし */ 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 add_complex (struct complex z1, struct complex z2) { /* ローカル変数宣言 */ struct complex sum;/*2つの複素数の和を蓄える */ /* 計算処理 */ (sum.real)=(z1.real)+(z2.real); /* 実部の計算 */ (sum.imag)=(z1.imag)+(z2.imag);/* 虚部の計算 */ return sum; } /* 関数 add_complex の定義終了 */ /* プログラム addcomp.c の終了 */ 29

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