mirror of
https://github.com/krahets/hello-algo.git
synced 2026-06-17 07:38:23 +08:00
82 lines
2.0 KiB
C
82 lines
2.0 KiB
C
/**
|
||
* File: iteration.c
|
||
* Created Time: 2023-09-09
|
||
* Author: Gonglja (glj0@outlook.com), MwumLi (mwumli@hotmail.com)
|
||
*/
|
||
|
||
#include "../utils/common.h"
|
||
|
||
/* for ループ */
|
||
int forLoop(int n) {
|
||
int res = 0;
|
||
// 1, 2, ..., n-1, n を順に加算する
|
||
for (int i = 1; i <= n; i++) {
|
||
res += i;
|
||
}
|
||
return res;
|
||
}
|
||
|
||
/* while ループ */
|
||
int whileLoop(int n) {
|
||
int res = 0;
|
||
int i = 1; // 条件変数を初期化する
|
||
// 1, 2, ..., n-1, n を順に加算する
|
||
while (i <= n) {
|
||
res += i;
|
||
i++; // 条件変数を更新する
|
||
}
|
||
return res;
|
||
}
|
||
|
||
/* while ループ(2回更新) */
|
||
int whileLoopII(int n) {
|
||
int res = 0;
|
||
int i = 1; // 条件変数を初期化する
|
||
// 1, 4, 10, ... を順に加算する
|
||
while (i <= n) {
|
||
res += i;
|
||
// 条件変数を更新する
|
||
i++;
|
||
i *= 2;
|
||
}
|
||
return res;
|
||
}
|
||
|
||
/* 二重 for ループ */
|
||
char *nestedForLoop(int n) {
|
||
// n * n は対応する点の個数であり、"(i, j), " に対応する文字列長の最大は 6+10*2 で、さらに末尾の空文字 \0 のための追加領域が必要
|
||
int size = n * n * 26 + 1;
|
||
char *res = malloc(size * sizeof(char));
|
||
// i = 1, 2, ..., n-1, n とループする
|
||
for (int i = 1; i <= n; i++) {
|
||
// j = 1, 2, ..., n-1, n とループする
|
||
for (int j = 1; j <= n; j++) {
|
||
char tmp[26];
|
||
snprintf(tmp, sizeof(tmp), "(%d, %d), ", i, j);
|
||
strncat(res, tmp, size - strlen(res) - 1);
|
||
}
|
||
}
|
||
return res;
|
||
}
|
||
|
||
/* Driver Code */
|
||
int main() {
|
||
int n = 5;
|
||
int res;
|
||
|
||
res = forLoop(n);
|
||
printf("\nfor ループの合計結果 res = %d\n", res);
|
||
|
||
res = whileLoop(n);
|
||
printf("\nwhile ループの合計結果 res = %d\n", res);
|
||
|
||
res = whileLoopII(n);
|
||
printf("\nwhile ループ(2回更新)の合計結果 res = %d\n", res);
|
||
|
||
char *resStr = nestedForLoop(n);
|
||
printf("\n二重 for ループの走査結果 %s\r\n", resStr);
|
||
free(resStr);
|
||
|
||
return 0;
|
||
}
|