2255 . 综合题

假设输入的 x 是不超过 1000 的自然数

#include <stdio.h>
using namespace std;

#define n 100000
#define N n+1

int m;
int a[N], b[N], c[N], d[N];
int f[N], g[N];

void init() 
{
 f[1] = g[1] = 1;
 for (int i = 2; i <= n; i++) {
  if (!a[i]) {
   b[m++] = i;
   c[i] = 1, f[i] = 2;
   d[i] = 1, g[i] = i + 1;
  }
  for (int j = 0; j < m && b[j] * i <= n; j++) {
   int k = b[j];
   a[i * k] = 1;
   if (i % k == 0) {
    c[i * k] = c[i] + 1;
    f[i * k] = f[i] / c[i * k] * (c[i * k] + 1);
    d[i * k] = d[i];
    g[i * k] = g[i] * k + d[i];
    break;
   }
   else {
    c[i * k] = 1;
    f[i * k] = 2 * f[i];
    d[i * k] = g[i];
    g[i * k] = g[i] * (k + 1);
   }
  }
 }
}

int main() 
{
 init();

 int x;
 scanf("%d", &x);
 printf("%d %d\n", f[x], g[x]);
 return 0;
}

假设输入的 $x$ 是不超过 $1000$ 的自然数,完成下面的判断题和单选题:

1 . (判断题)

若输入不为 1,把第 13 行删去不会影响输出的结果。( )

2 . (判断题)

第 25 行的 f[i] / c[i * k]可能存在无法整除而向下取整的情况。 ( )

3 . (判断题)

在执行完 init() 后,f 数组不是单调递增的,但 g 数组是单调递增的。 ( )

4 . (单选题)

init 函数的时间复杂度为( )。

5 . (单选题)

在执行完 init() 后,$f[1], f[2], f[3] \dots f[100]$ 中有()个等于 2。

6 . (单选题)

当输入为 1000 时,输出为()