Как уже упоминалось в комментариях, при разбиении содержимого массива распознайте, что каждый элемент находится в определенном адресуемом месте в памяти, что делает эту работу идеальной для memcpy () ,Вот простая иллюстрация, использующая эту концепцию:
int main(void)
{
double source[] = {3.4,5.6,2.3,4.5,6.7,8.9,10.1,11.1,12.3,4.5};
double split1[3];
double split2[7];
memcpy(split1, &source[0], 3*sizeof(double));
memcpy(split2, &source[3], 7*sizeof(double));
return 0;
}
Если ваш проект имеет четко определенные и статические параметры, которые известны во время выполнения, тогда с помощью нескольких распространенных макросов и некоторых дополнительных переменных это можно сделатьнемного более общий.
Следующий пример по сути аналогичен приведенному выше рисунку, но в цикле, потенциально более адаптируемой конструкции.
#define SPLIT_CNT 3
int main(void)
{
double source[] = {3.4,5.6,2.3,4.5,6.7,8.9,10.1,11.1,12.3,4.5,8.5,9.5};
double split1[3]; // arrays if differing sizes
double split2[7];
double split3[2];
size_t start_pos; //position accumulator
size_t cpy_len[SPLIT_CNT] = {3,7,2}; //known array sections
double *split[] = {split1,split2,split3}; //enables looping on arrays of differing sizes
start_pos = 0;
for(int i=0;i<SPLIT_CNT;i++)
{
if(i > 0)start_pos += cpy_len[i-1]; //move the start postition
memcpy(split[i], &source[start_pos], sizeof(double)*cpy_len[i]);
}
return 0;
}