例如本人有一个数组,元素个数大于0,求一个算法使这个数组的个数假如是小于5的话就保持不变,假如数组元素的个数大于5,通过算法使其只留5个,而且最终元素要是原来数组元素差不多间距位置的元素。例如:
Array_1={1,2,3} 那么:Array_1={1,2,3} ;
Array_1={1,2,3,4,5,6,7} 那么:Array_1={1,3,5,6,7};
Array_1={1,2,3,4,5,6,7,8,9} 那么:Array_1={1,3,5,7,9};
Array_1={1,2,3,4,5,6,7,8,9,10} 那么:Array_1={1,3,5,7,9};
Array_1={1,2,3,4,5,6,7,8,9,10,11} 那么:Array_1={1,5,7,9,11};
差不多这个意思,求高手赐教
Array_1={1,2,3} 那么:Array_1={1,2,3} ;
Array_1={1,2,3,4,5,6,7} 那么:Array_1={1,3,5,6,7};
Array_1={1,2,3,4,5,6,7,8,9} 那么:Array_1={1,3,5,7,9};
Array_1={1,2,3,4,5,6,7,8,9,10} 那么:Array_1={1,3,5,7,9};
Array_1={1,2,3,4,5,6,7,8,9,10,11} 那么:Array_1={1,5,7,9,11};
差不多这个意思,求高手赐教
解决方案
40
等间距取元素吗?
#include <stdio.h>
int filter(int* src,int ns,int* result,int nr)
{
int step; //采样步长
int o = 0; //输出序号
int i;
int r; //执行除法的余数
int op = 0; //按step+1采样的个数
if(ns <= 0) return o;
if(ns <= nr) //样本小时逐个输出
{
step = 0;
op = nr = ns;
}
else
{
step = (ns - 1) / (nr - 1);
r = (ns - 1) % (nr - 1);
if(r >= step) //仅余数大于步长时将多出的加到前几次采样中
op = r;
}
for(i=0,o=0;o<nr;o++){
result[o] = src[i];
i += step;
if(o < op) i++;
}
return o;
}
void show(int* arry,int len)
{
int i;
for(i=0; i<len; i++)
{
if(i != 0) printf(",");
printf("%d",arry[i]);
}
printf("\n");
}
int main()
{
int Array_1[13];
int result[5];
int i,o,n;
for(i=0; i<sizeof(Array_1)/sizeof(int); i++)
Array_1[i] = i + 1;
for(n=0; n<sizeof(Array_1)/sizeof(int); n++)
{
o = filter(Array_1,n,result,sizeof(result)/sizeof(int));
printf("src: ");
show(Array_1,n);
printf("dst: ");
show(result,o);
printf("\n");
}
return 0;
}
运行结果如下:
红框框出不一致的地方,应该是题主的问题吧?