第7講 ポインタ
第6話 ポインタによる成績一覧表プログラム
ポインタによるプログラム例
#include<stdio.h> //prinf()を使えるようにするためにインクルード
#include<stdlib.h> //rand()を使用できるようにインクルード
#include <time.h> //time()を使用できるようにインクルード
void f();
int main() {
f();
}
void f() {
int i, j, k; //for文の制御変数
float h[3][10]; //平均点を収納する箱
int ***a = (int ***)malloc(sizeof(int **) * 3); //配列と制御変数の定義
for (i = 0; i < 3; i++)a[i] = (int **)malloc(sizeof(int *) * 10);
for (i = 0; i < 3; i++) {
for (j = 0; j < 10; j++)a[i][j] = (int *)malloc(sizeof(int *) * 6);
}
srand((unsigned)time(NULL)); //乱数の系列決定するシード値を現在時刻から取得
//ランダムデータ発生
for (i = 0; i < 3; i++) {
for (j = 0; j < 10; j++) {
for (k = 0; k < 5; k++) {
a[i][j][k] = rand() % 100 + 1;
}
}
}
//合計点と平均点の算出
for (i = 0; i < 3; i++) {
for (j = 0; j < 10; j++) {
a[i][j][5] = 0; //0に初期化
for (k = 0; k < 5; k++) {
a[i][j][5] += a[i][j][k]; //合計点の算出
}
h[i][j] = (float)a[i][j][5] / 5; //平均点の算出
}
}
//結果表示
for (i = 0; i < 3; i++) {
printf("%d学期\n", i + 1);
printf("出席番号 国語 社会 数学 理科 英語 合計 平均\n");
for (j = 0; j < 10; j++) {
if (j + 1<10)printf(" %d ", j + 1); else printf(" %d ", j + 1);
for (k = 0; k < 6; k++) {
if (a[i][j][k]<10)printf(" %d ", a[i][j][k]);
if (a[i][j][k] >= 10 && a[i][j][k]<100)printf(" %d ", a[i][j][k]);
if (a[i][j][k] >= 100)printf("%d ", a[i][j][k]);
}
printf("%.1f", h[i][j]);
printf("\n");
}
printf("\n");
}
}
本当は、配列のところで触れるべき話題でしたが、
配列とポインタは、本質的に変わらないですから、
2次元配列と1次元配列の関係をここで考えてみることにしましょう。
2次元配列のイメージは
a[0][0],a[0][1],a[0][2],
a[1][0],a[1][1],a[1][2],
a[2][0],a[2][1],a[2][2],
a[3][0],a[3][1],a[3][2]
ですが、メモリの番地は1次元で並んでいますから、
実際上は
a[0][0],a[0][1],a[0][2],a[1][0],a[1][1],a[1][2],a[2][0],a[2][1],a[2][2],a[3][0],a[3][1],a[3][2]
と並んでいます。
つまり1次元です。
だとすれば、2次元や3次元でやれることは1次元でも出来るはずです。
そこで課題です。
コード
#include<stdio.h>
#include<stdlib.h> //malloc()を使うためにインクルード
void f(); //2次元配列による処理
int main() {
f();
return(0);
}
void f() {
int i, j;
//2次元配列の用意
int **a = (int **)malloc(sizeof(int *) * 7);
for (i = 0; i < 7; i++)a[i] = (int *)malloc(sizeof(int) * 6);
//データ作成
for (i = 0; i < 7; i++) {
for (j = 0; j < 6; j++) {
a[i][j] = 6 * i + j + 1;
}
}
//データの表示
for (i = 0; i < 7; i++) {
for (j = 0; j < 6; j++) {
if(a[i][j]<10)printf(" %d ",a[i][j]);
if (a[i][j]>=10)printf("%d ", a[i][j]);
}
printf("\n");
}
}
の実行結果は
ですが、社員g()を採用して、
社員g()には、1次元配列で同じ処理をさせて、
を実現して下さい。
前半が関数f()による仕事で、後半が関数g()による仕事です。