【解题思路】
其实这一关比较难的是数学逻辑,但是它的提示给了,按照提示,其实可以简化一下,首先我们统一一下c、b的下标,因为我觉得题目里面标的让我有点混乱,所以自己重新总结了一下。如果把m%放在一个数组里面储存,再统一一下下标,其实上面提示中的等式,可以改为下面等式:
改成这样就比较简单了,用一个for循环就可以算出来了。
#include<stdio.h>
int main()
{
int n,m=0;
scanf("%d %d",&n,&m);
int a[n+1];
int b[n+1];
int c[n+1];
//存放m%c
int arr[n+1];
c[0] = 1;
int i = 0;
scanf("%d",&a[0]);
for(i = 1;i < n;i++)
{
scanf("%d",&a[i]);
c[i] = c[i-1] * a[i-1];
arr[i-1] = m % c[i];
}
arr[n-1] = m;
b[0] = arr[0] / c[0];
printf("%d ",b[0]);
for(i = 1 ;i < n;i++)
{
b[i] = (arr[i] - arr[i-1] )/c[i];
printf("%d ",b[i]);
}
return 0;
}