mirror of
https://github.com/krahets/hello-algo.git
synced 2026-06-28 00:24:21 +00:00
d7b2277d2b
* Retranslate Japanese docs with GPT-5.4 * Retranslate Japanese code with GPT-5.4
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;
|
|
}
|