我想循环遍历数组的元素,对于这些元素中的每一个,我必须调用一个指向的函数,并将元素地址与存储的地址一起传递在最后一个参数中。该函数返回函数指向的元素的数量返回true。这是我一直努力遵循的要求,但我不能让我的功能做的到底是什么要求做..第一个元素指向的数组移动通过元素的函数
------要求&功能------- -----
/* Write an enumeration function named sum() with the following parameters: a generic pointer an int that holds the number of elements in the array pointed to an int that holds the size in bytes of a single element a pointer to a function that has two generic pointer parameters and returns a bool a generic pointer Your function moves through the array pointed to by the first parameter element by element. For each element, your function calls the function pointed to and passes the element's address along with the address stored in the last parameter. Your function returns the number of elements for which the function pointed to returned true. Since your first function parameter is a generic pointer and your function can handle any type, you will need to cast the address of the input array to the address of a chars in order to move from one element to the next. */
INT总和(无效* X,INT N,int类型,布尔(F)(空隙,无效*),无效* Z){
char *arr = static_cast<char*>(x); int count = 0; for (; s < n-2; s++){ arr += s; count += f(arr, z); } if (n/1 == n) return count; else if (n % 2 == 0) return count; else return 0;
}
我希望你们能告诉我,解释或者至少是我不是正确的方式做..我会很感激这是唯一的办法,我能学到.. :)
如果需要更多的解释,请让我知道..
** * ***加成* ** * ***
/* Write a callback function named isEven() with the following parameters: a generic pointer to an input value a generic pointer to an output value Your function works with ints and returns true if the input value is even, false otherwise. Moreover, if the value is even, your function adds the value to that pointed to by the second parameter. */ bool isEven(void* x, void* z){ int a = *static_cast<int*>(x); int b = *static_cast<int*>(z); if (a % 2 == 0){ // finding even numbers b += a; return true; } else { return false; } } /* Write another callback function named isPrime() with the following parameters: a generic pointer to an input value a generic pointer to an output value Your function works with ints and returns true if the input value is a prime number, false otherwise. Moreover, if the value is prime, your function adds the value to that pointed to by the second parameter. */ bool isPrime(void* x, void* z){ int a = *static_cast<int*>(x); int b = *static_cast<int*>(z); if ((a/1 == a) && (a/a == 1)){ // finding prime numbers b += a; return true; } else { return false; } }
** * ** * ****预期输出* ** * ** * ** * *
5 evens found in {1,2,3,4,5,6,7,8,9,10,11} sum is 30 5 primes found in {1,2,3,4,5,6,7,8,9,10,11} sum is 28
在C++世界中,不要使用void指针而不是函数指针。有更好的方法(模板/虚拟方法) –
@EdHeal,但显然他必须 – Paranaix
是的,我必须以这种方式使用它.. – NorthBlast