Programación orientada a objetos C ++ 029: Filtro simple ---- (Mooc de la Universidad de Pekín)

Directorio de artículos


Titulo original

Inserte la descripción de la imagen aquí

#include <iostream>
#include <string>
using namespace std;
// 在此处补充你的代码
bool LargerThan2(int n)
{
    
    
	return n > 2;
}
bool LongerThan3(string s) 
{
    
    
	return s.length() > 3;
}

string as1[5] = {
    
    "Tom","Mike","Jack","Ted","Lucy"};
string as2[5];
int  a1[5] = {
    
     1,2,3,4,5};
int a2[5];
int main() {
    
    
	string * p = Filter(as1,as1+5,as2,LongerThan3);
	for(int i = 0;i < p - as2; ++i)
		cout << as2[i];
	cout << endl; 
	int * p2 = Filter(a1,a1+5,a2,LargerThan2);
	for(int i = 0;i < p2-a2; ++i)
		cout << a2[i] << ",";
	return 0;
}


Código

template <class T1,class T2>
T1* Filter(T1* startptr,T1* endptr,T1* setarray,T2* judge)
{
    
    
    T1* temp = startptr;
    int tempcount = 0;
    for(;temp != endptr;temp++)
    {
    
    
        if((*judge)(*temp))
            setarray[tempcount++] = *temp;
    }

    return setarray+tempcount;
}

Supongo que te gusta

Origin blog.csdn.net/qq_37500516/article/details/114991798
Recomendado
Clasificación