この章では配列について説明します。
普通の変数は1つしかデータを入れることができません。
他のデータを入れようとするとデータが上書きされてしまいます。
それに対して、配列は複数のデータをまとめて入れることができます。
複数のデータをまとめて扱う場合、普通の変数では以下のように別々の変数名でそれぞれのデータを入れなければいけません。 それに対して配列を使うと次のように1つの変数名で同じ型のデータを複数入れることができるのです。
同じ目的で使用する変数は1つにまとめてしまい、1つの変数で複数の要素を管理できると便利です。
このような時に配列を使用します。
では例をみてみましょう。
変数と同じように配列も以下のように宣言をしなくてはいけません。
つまり、「どの型名でいくつのデータ」を扱う配列を作成するのかを宣言します。 要素数とは配列に入れるデータの数です。
この例では以下のように宣言しています。
int person[4];
これはint型の要素が入る箱を4つ用意することを意味します。
宣言をした後にはデータを入れるのですが、それが次の箇所です。
箱を4つ用意したので入れるデータも4つです。 配列にデータを入れる基本構文は以下の通りです。 構文の[ ]の中に入っている数値を添え字またはインデックスと言います。
添え字とはデータが入っている場所を意味します。
例えば、コインロッカーには番号が振ってありますが、この番号があるからこそ、どこに自分の荷物があるのかが分かるわけです。
添え字の考え方も同じで、0から始まっている番号で配列のデータを管理します。 添え字は0から順番に番号が付けられていきます。
1から始まるわけではないので注意してください。
配列の書き方はこの他にもあります。
それは配列の宣言と初期化を一緒に行う方法です。 右辺はデータをカンマで区切ります。
上の構文で、最初の例で作成した配列を書き換えると以下のようになります。 配列に関する注意点が2つあります。
1つ目は以下の例のように要素数が5つであるにも関わらず、6個のデータを入れようとするとエラーになります。 2つ目は配列の2つ目の書き方を紹介しましたが、以下のように要素数を省略できます。 この場合は代入するデータの数が配列の要素数になります。
上の例の場合は要素数は6つなので、自動的に6を指定したことと同じ意味になります。
次は配列の要素を出力する方法について説明します。
以下が配列の要素を出力している箇所です(紙面の都合で2行で書いていますが、1行で書いてもいいです)。
次は文字列を配列で扱う方法について説明します。 文字列とは複数の「文字」を並べたものです。
char型の文字を複数並べることで文字列を作ることが出来ます。
char型の文字を複数並べるにはchar型の配列を使います。
char型の配列の作成手順は以下の通りです。
最初にchar型の配列を宣言してください。 次に配列の要素に1文字ずつ入れていきます。 実は文字列(この例ではdog)には文字列の最後に(ヌル文字と言います)と言う文字が隠れていまして、意味はを意味します。
ですので、配列の最後の要素にを付け加えてください。
その分、配列の要素数も1つ増えるので、配列の要素数もではなくてになります。
配列を出力している箇所は以下の箇所です。 結果は「dog」 を出力します。
char型の配列文字を出力する時の変換指定文字はになります。
月: 2015年5月
puts関数をもっと知ろう
scanf関数について知ろう
この章ではscanf関数について説明します。
scanf関数はユーザーがキーボードから入力したデータを取得するための関数です。
例えば「あなたの年齢は?」と質問するとプログラムはユーザーが年齢を入力するまで待ちます。
そして、この入力された年齢をプログラムに取り込むことが出来ます。
では例をみてみましょう。 では説明を始めます。 =>ユーザーが入力したデータを入れるための変数の宣言をします。
年齢を入力するので、型はintにします。 =>「年齢は?」を出力します。 =>scanf 関数はユーザーが年齢を入力してくれるのを待ちますので、一回プログラムが止まります。
そして、例えばユーザーが23と入力したのならば、その23がaに入ります。
scanfもprintfと同じように変換指定子を指定しますが、例の場合は整数を入力するのでを指定しています。
注意してほしいことはscanfの中の変数の前に&を付けることを忘れないでください。
最後に以下の箇所で出力します。 では例をみてみましょう。 結果は以下の通りです。
加算子,減算子について知ろう
この章では加算子,減算子について説明します。
加算子は数値を1つ増やし、減算子は数値を1つ減らす演算子です。
加算子は減算子はで表示します。
まだ説明していませんが、for文などの繰り返し構文等に主に使われます。 では例をみてみましょう。 a1++;も++a2;も変数の値である2に1を足しているので、結果は同じ3になります。
つまり、単独でを使用する場合には結果は同じになります(++が前にあっても、後ろにあっても結果は同じです)。
次は前置加算子について詳しく説明します。 「++a」は「a=a+1」と同じです。
つまり「a+1」を計算してから、左辺のaに結果を代入して、printfで出力していますので、のは4になります。
aはこの時点で4に変化しているのでのaも4になります。
前置加算子の例は特に変わったところが無いので解りやすいですが、次の後置加算子の例は少し複雑になります。
後置加算子の例をみてみましょう。 後置加算子では初めにを無視した状態で出力し、それからaに1を加算します。 つまり、この例ではaの値である3を出力してから、aに1を足しています。
キャスト演算子について知ろう
この章ではキャスト演算子について説明します。
型が違う変数同士の計算の場合にはサイズが大きい型に自動的に型変換されていましたが、自身で型変換をする方法もあります。
それはキャスト演算子を使う方法です。
では初めにキャスト演算子を使わない例をみてみましょう。 結果は「3.000000」になります。
算数の計算では答えは3.25になりますが、int同士の計算なので、小数点以下が削除されてから、double型の変数eに代入されます。
これでは正確な計算は出来ませんね。
そこで変数の前にを付けることで、その指定した型に換えることが出来ます。 結果は「3.250000」となり、正確に計算できます。
この例の場合は以下のように両方ともキャストしていますが実は両方ともキャストする必要はありません。 doubleのほうがintより大きい型なのでfとvの片方だけdoubleにキャストすることで、もう片方の変数もdoubleに変換されます。
つまりのように片方でも同じ結果になります。
C言語で計算をしよう
この章では算術演算子について説明します。
算術演算子とは計算するための記号です。 number1+number2は加算を行っているのですが、number1には5、number2には3が入っているので、この変数の値同士を足しています。
特に数値を変数に入れる必要性がないのであればと計算していただいても結構です。
number1-number2は減算を行っているのですが、number1には5、number2には3が入っているので、この変数の値同士を引いています。
特に数値を変数に入れる必要性がないのであればと計算していただいても結構です。
は乗算を行っているのですが、number1には5、number2には3が入っているので、この変数の値同士を掛けています。
特に数値を変数に入れる必要性がないのであればと計算していただいても結構です。
number1/number2は除算を行っているのですが、number1には5、number2には3が入っているので、この変数の値同士を割っています。
特に数値を変数に入れる必要性がないのであればと計算していただいても結構です。
number1%number2は剰余を行っているのですが、number1には5、number2には3が入っているので、この変数の値同士の割り算の余りを算出します。
特に数値を変数に入れる必要性がないのであればと計算していただいても結構です。
は掛け算と足し算を行っているのですが、計算の優先順位は掛け算が先です。
掛け算を行ってから足し算を行います。
これは算数の計算順序と同じです。
足し算から計算したい場合はと、カッコを足し算に付け加えてください。
カッコを付けることで優先順位が掛け算より高くなります。
以下の例は先ほどの例を書き換えた例です。
一度計算結果を変数に入れてから、printfで出力しています。
次の例は型が違うデータ同士の計算の例です。 結果は以下の通りです。
「結果は5.400000です」
「a+r」の部分でint型の変数とdouble型の変数を足しています。
このようにサイズの小さい型とサイズの大きい型を足すとサイズが大きい型に統一されてから計算されます。
サイズの大小は以下のようになります。 ですので、「a+r」はaの値が2.0に変換されるのでとなります。
つまり、int型がdouble型に変換されてから足されます。
では次の例をみてみましょう。 「a*g」は掛け算ですので、足し算より優先的に計算されます。
そしてaがint型、gがlong型なので、精度の高いlong型に統一されます(つまり、計算する前からaはlong型に統一されます)。
そして、その結果をdouble型のrと足します。
long型とdouble型はどちらが精度が高いでしょうか?下を見ていただければわかりますが、double型のほうが高いですので「a*g」の結果である12はdouble型に変換されてから、3.567を足します。
つまり、式の中で変数の型が異なる時、一番大きい型(精度の高い型)に統一されます。
printfについてもっと知ろう
この章では変換指定文字について説明します。
以下がprintfの変換指定文字です。 次の例では出力される値の表示幅を指定する方法について説明します。 結果は以下のように出力されます。 「%」と「d」の間に数値を入れると、その数値は表示幅を意味します。
この例では5を入力しているので567をで表示しますが、先頭の2文字分が開いてしまうので、そこにはスペースが入れられます。
出力結果を見ていただくと2文字分のスペースが開いているのが分かります。
のようにデータの桁数と同じか、もしくは小さい場合には何も指定していないのと同じになります。
「%」と「d」の間に先頭の0を含めた数字を入れると表示幅を意味するのは上の例と同じです。
上の例と違うのは数値を右詰めで表示したときの余ったスペースは0で埋められることです。
この例は05を入力しているので567を右詰めで5桁で表示しますが、先頭の2文字分が開いてしまうので、その場合には0が入れられます。
では次の例をみてみましょう。 結果は以下の通りです。 では説明をしていきます。 =>「%」と「f」の間に数字を入れると、それは表示幅を意味します。
浮動小数点数の場合には小数点も入れた表示幅になりますので、この例では先頭の1文字分が開いてしまいます。
その場合にはスペースが入れられます。
出力結果の上から2つ目を見ていただくと1文字分のスペースが開いているのが分かります。
=>「%」と「f」の間に先頭の0を含めたの数字を入れると表示幅を意味するのは上の例と同じです。
先ほどの例と違うのは数値を右詰めで表示したときの余ったスペースは0で埋められることです。
浮動小数点数の場合には小数点も入れた表示幅になりますので、この例では先頭の1文字分が開いてしまいます。
その場合には0が入れられます。出力結果の上から3つ目を見ていただくと1文字分のスペースが0で埋められているのが分かります。
=>「%」と「f」の間に小数点を含めた数字を入れると点の左側の数値が表示幅を示し、点の右側の数値が小数点以下の桁数を示します。
例では9桁の表示幅で小数点以下は2桁で設定していますが、余りはスペースで埋められます。
以下の例で10進数である100を8進数と16進数に変えています。 int型の整数を8進数に変えるにはを使います。
int型の整数を16進数に変えるにはを使います。 =>100を8進数で表すと0144ですので、出力結果はになります。
144の前の0が省略された形で出力されます。
=>100を16進数で表すと0x64ですので、出力結果はになります。
64の前の0xが省略された形で出力されます。
次の例は0や0xを省略しないで表示させる例です。 8進数で0を省略しないで表示するには%とoの間に#を付けます。
16進数で0xを省略しないで表示するには%とxの間に#を付けます。
結果は以下の通りです。 次の例はテンプレートの中で%を文字として(パーセントとして)出力する場合の例です。 テンプレートの中で%を文字として(パーセントとして)出力したい場合はと指定することで%を出力することができます。
結果はです。
データ型についてもっと知ろう
データ型について知ろう
この章ではデータ型について説明します。
変数の宣言時に、変数に入れるデータがどのような性質のものなのかを指定するのがデータ型です。
例えばの場合はintが付いていますが、これは整数だけがaという変数に入れることができます。
データ型は以下の種類に分類することが出来ます。
「整数型」
「浮動小数点数型」
「文字型」
「論理型」
初めに整数型から説明します
整数とは「少数点のない値」のことを言います。
整数は10進数、8進数、16進数などで表せますが10進数は1や100などの我々が普段使っている数字です。
8進数は先頭に0を付けて0144などと書きます。
16進数は先頭に0xを付けて0x41などと書きます。
変数に入れるデータが整数の場合には変数の前にintを付けます。
このintは符号付き整数と呼ばれていまして、プラスの値とマイナスの値が使用できる型です。
以下の例の場合には2という整数を変数に入れるのでintを変数名の前に付けています。 整数には符号付き整数の他に符号無し整数があります。
以下の表を見ていただくと分かりますが、符号無し整数はマイナスの値がない分をプラスに使えるので、プラスの扱える範囲が倍になります。 では「int」や「unsigned int」以外の型(unsigned short,short)を見てみましょう。
では次の型(long intとunsigned long)進みます。
では次の型(long long,unsigned long long)に進みます。
次は浮動小数点数型について説明します。 浮動小数点数は少数点を持つ数値のことをいいますので、などと表現します。
整数型の最大値を超える場合は浮動小数点数型を使います。
浮動小数点数型はdouble型とfloat型の2種類が有ります。
double型は8バイト=64ビットのサイズで、倍精度浮動小数点数型と呼ばれていますが、桁数が15桁まで表現できます。
float型は4バイト=32ビットのサイズで桁数が8桁まで表現できます。
float型は30.0Fなどと末尾にFもしくはfを付けます。
今ではfloat型はほとんど使われていないので、double型を使用するようにしてください。
では例をみてみましょう。 printfでfloat型やdouble型のデータを出力するにはを使います。
次は文字型について説明します。 文字型(char 型)は半角英数字1文字をシングルクォートで囲んだ形で表します。
文字型の値は1バイトで表現されるため、1バイトで表現可能な文字でなければなりません。
日本語のような全角文字のをシングルクォートで囲っても char 型にはなりません。
文字列(例えば”ねこ”)とは異なり、文字型で表現できのは半角の1文字と覚えてください。
例えば以下のシングルクォートで囲まれたデータは文字型です。 もう一つ注意してほしいことは文字型は文字という名前が付いていますが、実は文字はコンピュータの中では整数の値として保持されています。
ですので、charは半角英数字1文字の他にまでの整数を入れることができます。
その他に「Unsigned char」があります。
これは「半角英数字1文字」の他にまでの整数値を入れることができます。
では例をみてみましょう。printfで文字型を出力するときの変換指定子はです。