アフィリエイト広告を利用しています

広告

posted by fanblog

2017年11月18日

《その139》 乱数の生成 & p.97演習3-1


 乱数の生成

 ヘッダ<cstdlib>, srand関数, rand関数、自分は何でもすぐ忘れてしまうので、後々のために乱数生成の定番手法を書いておこうと思います。

------------------------------------------
#include <ctime>
#include <cstdlib>
#include <iostream>
using namespace std;

int main() {
int a[10];

// 乱数を生成するためのタネとして現在時刻を与える。
srand(time(NULL));

for (int i = 0; i < 10; i++) {
// 100 〜 200 の乱数
a[i] = rand() % 101 + 100;
cout << a[i] << " ";
}
cout << '\n';
}
------------------------------------------



新版明解C++中級編 p.97 演習3-1
 以下のプログラムは、成績が『良』の識別表示と『優または可』の識別表示を行うプログラムである。
これら以外の条件でも識別表示するように変更したプログラムを作成せよ。
------------------------------------------
#include <ctime>
#include <cstdlib>
#include <iostream>
using namespace std;

// 良[B:70〜79] であるか
bool isB(int x) {
return x >= 70 && x <= 79;
}

// 優[A:80〜100] or 可[C:60〜69] であるか
bool isAorC(int x) {
return (x >= 80 && x <= 100) || (x >= 60 && x <= 69);
}

// fit(x)の返却値が真 true であれば ★印を付けて表示
void put_list(const int a[], int n, bool fit(int)) {
for (int i = 0; i < n; i++) {
if (fit(a[i]))
cout << "★";
else
cout << " ";
cout << "a[" << i << "] = " << a[i] << '\n';
}
}

int main() {
int a[10]; // 点数を格納
int n = sizeof(a) / sizeof(a[0]);

srand(time(NULL));

for (int i = 0; i < n; i++)
a[i] = rand() % 101; // 0〜100の乱数

cout << "良----------\n";
put_list(a, n, isB); // 良 に★を付けて表示

cout << "\n優または可--\n";
put_list(a, n, isAorC); // 優 or可 に★を付けて表示
}
------------------------------------------

// p97_演習3-1
#include <ctime>
#include <cstdlib>
#include <iostream>
using namespace std;

// 優[A:80〜100] であるか
bool isA(int x) {
return x >= 80;
}

// 良[B:70〜79] であるか
bool isB(int x) {
return x >= 70 && x <= 79;
}

// 可[C:60〜69] であるか
bool isC(int x) {
return x >= 60 && x <= 69;
}

// 不可[D:0〜59] であるか
bool isD(int x) {
return x <= 59;
}

// 優[A:80〜100] or 可[C:60〜69] であるか
bool isAorC(int x) {
return (x >= 80 && x <= 100) || (x >= 60 && x <= 69);
}

// fit(x)の返却値が真 true であれば ★印を付けて表示
void put_list(const int a[], int n, bool fit(int)) {
for (int i = 0; i < n; i++) {
if (fit(a[i]))
cout << "★";
else
cout << " ";
cout << "a[" << i << "] = " << a[i] << '\n';
}
}

int main() {
int a[10];
int n = sizeof(a) / sizeof(a[0]);

srand(time(NULL));

for (int i = 0; i < n; i++) {
a[i] = rand() % 81 + 20;
if (a[i] <= 59) // 不可の人は再試験 (^ ^;)
a[i] = rand() % 81 + 20;
}

cout << "優----------\n";
put_list(a, n, isA);

cout << "\n良----------\n";
put_list(a, n, isB);

cout << "\n可----------\n";
put_list(a, n, isC);

cout << "\n不可--------\n";
put_list(a, n, isD);

cout << "\n優または可--\n";
put_list(a, n, isAorC);
}

d03_01.png


新版 明解C 入門編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:13時点)

新版 明解C 中級編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:14時点)





この記事へのコメント
コメントを書く

お名前:

メールアドレス:


ホームページアドレス:

コメント:

※ブログオーナーが承認したコメントのみ表示されます。

この記事へのトラックバックURL
https://fanblogs.jp/tb/6984132
※ブログオーナーが承認したトラックバックのみ表示されます。

この記事へのトラックバック

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


検索
<< 2018年08月 >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
プロフィール
こうすけさんの画像
こうすけ

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


×

この広告は30日以上新しい記事の更新がないブログに表示されております。