18.03.31 模板作业
A:这个模板并不难
描述
程序填空,输出指定结果
#include <iostream> #include <string> #include <cstring> using namespace std; template <class T> class myclass { // 在此处补充你的代码 ~myclass( ) { delete [] p; } void Show() { for( int i = 0;i < size;i ++ ) { cout << p[i] << ","; } cout << endl; } }; int a[100]; int main() { char line[100]; while( cin >> line ) { myclass<char> obj(line,strlen(line));; obj.Show(); int n; cin >> n; for(int i = 0;i < n; ++i) cin >> a[i]; myclass<int> obj2(a,n); obj2.Show(); } return 0; }
输入
多组数据。每组第一行是一个不含空格的字符串
第二行是整数n
第三行是n个整数输出对每组数据,先依次输出输入字符串的每个字母,并且在每个字母后面加逗号
然后依次再输出输入的n个整数 ,在每个整数后面加逗号样例输入
Tom 
3
3 4 5
Jack
4
1 2 3 4
样例输出
T,o,m,
3,4,5,
J,a,c,k,
1,2,3,4,
来源Guo Wei
 
1 #include <iostream> 2 #include <string> 3 #include <cstring> 4 using namespace std; 5 template <class T> 6 class myclass { 7 //s 8 public: 9 T *p; 10 int size; 11 myclass(T *line, int len) { 12 p = new T[len+1]; 13 size = len; 14 for (int i = 0; i<size; i++) 15 p[i] = line[i]; 16 p[len] = 0; 17 } 18 //e 19 ~myclass( ) { 20 delete [] p; 21 } 22 void Show() 23 { 24 for( int i = 0;i < size;i ++ ) { 25 cout << p[i] << ","; 26 } 27 cout << endl; 28 } 29 }; 30 int a[100]; 31 int main() { 32 char line[100]; 33 while( cin >> line ) { 34 myclass<char> obj(line,strlen(line));; 35 obj.Show(); 36 int n; 37 cin >> n; 38 for(int i = 0;i < n; ++i) 39 cin >> a[i]; 40 myclass<int> obj2(a,n); 41 obj2.Show(); 42 } 43 return 0; 44 }
构造函数不能加 if(p)delete[]p
B:排序,又见排序!
描述
自己编写一个能对任何类型的数组进行排序的mysort函数模版。只能写一个mysort模板,不能写mysort函数!
#include <iostream> using namespace std; bool Greater2(int n1,int n2) { return n1 > n2; } bool Greater1(int n1,int n2) { return n1 < n2; } bool Greater3(double d1,double d2) { return d1 < d2; } template <class T1,class T2> void mysort( // 在此处补充你的代码 #define NUM 5 int main() { int an[NUM] = { 8,123,11,10,4 }; mysort(an,an+NUM,Greater1); //从小到大排序 for( int i = 0;i < NUM; i ++ ) cout << an[i] << ","; mysort(an,an+NUM,Greater2); //从大到小排序 cout << endl; for( int i = 0;i < NUM; i ++ ) cout << an[i] << ","; cout << endl; double d[6] = { 1.4,1.8,3.2,1.2,3.1,2.1}; mysort(d+1,d+5,Greater3); //将数组从下标1到下标4从小到大排序 for( int i = 0;i < 6; i ++ ) cout << d[i] << ","; return 0; }
输入
无
输出4,8,10,11,123,
123,11,10,8,4,
1.4,1.2,1.8,3.1,3.2,2.1,样例输入
无
样例输出
4,8,10,11,123,
123,11,10,8,4,
1.4,1.2,1.8,3.1,3.2,2.1,
来源Guo Wei
 
1 #include <iostream> 2 using namespace std; 3 4 bool Greater2(int n1,int n2) 5 { 6 return n1 > n2; 7 } 8 bool Greater1(int n1,int n2) 9 { 10 return n1 < n2; 11 } 12 bool Greater3(double d1,double d2) 13 { 14 return d1 < d2; 15 } 16 17 template <class T1,class T2> 18 void mysort( 19 T1*s, T1*e, T2(*h)(T1 a, T1 b)) { 20 int gap = e - s; 21 for(int i=0;i<gap-1;i++) 22 for (int j = 0; j < gap -1- i; j++) 23 { 24 T1 swap; 25 if (!(*h)(*(s+j),*(s+j+1))) 26 { 27 swap = *(s + j); 28 *(s + j) = *(s + j + 1); 29 *(s + j + 1) = swap; 30 } 31 } 32 } 33 #define NUM 5 34 int main() 35 { 36 int an[NUM] = { 8,123,11,10,4 }; 37 mysort(an,an+NUM,Greater1); //从小到大排序 38 for( int i = 0;i < NUM; i ++ ) 39 cout << an[i] << ","; 40 mysort(an,an+NUM,Greater2); //从大到小排序 41 cout << endl; 42 for( int i = 0;i < NUM; i ++ ) 43 cout << an[i] << ","; 44 cout << endl; 45 double d[6] = { 1.4,1.8,3.2,1.2,3.1,2.1}; 46 mysort(d+1,d+5,Greater3); //将数组从下标1到下标4从小到大排序 47 for( int i = 0;i < 6; i ++ ) 48 cout << d[i] << ","; 49 return 0; 50 }
C:山寨版istream_iterator
描述
模仿C++标准模板库istream_iterator用法,实现CMyistream_iterator使得程序按要求输出
#include <iostream> #include <string> using namespace std; template <class T> class CMyistream_iterator { // 在此处补充你的代码 }; int main() { int t; cin >> t; while( t -- ) { CMyistream_iterator<int> inputInt(cin); int n1,n2,n3; n1 = * inputInt; //读入 n1 int tmp = * inputInt; cout << tmp << endl; inputInt ++; n2 = * inputInt; //读入 n2 inputInt ++; n3 = * inputInt; //读入 n3 cout << n1 << " " << n2<< " " << n3 << " "; CMyistream_iterator<string> inputStr(cin); string s1,s2; s1 = * inputStr; inputStr ++; s2 = * inputStr; cout << s1 << " " << s2 << endl; } return 0; }
输入
第一行是整数t,表示有t组数据
每组数据一行,三个整数加两个字符串。字符串是不含空格的
输出
对每组数据,输出二行 
在第一行输出第一个数
第二行原样输出输入的内容
样例输入
2
79 90 20 hello me
12 34 19 take up
样例输出
79
79 90 20 hello me
12
12 34 19 take up
提示C++标准模板库 istream_iterator模版使用说明:
其构造函数执行过程中就会要求输入,然后每次执行++,则读取输入流中的下一个项目,执行 * 则返回上次从输入流中读取的项目。例如,下面程序运行时,就会等待用户输入数据,输入数据后程序才会结束:
#include 
#include 
using namespace std;
int main() { 
istream_iterator inputInt(cin);
return 0; 
}
下面程序运行时,如果输入 12 34 程序输出结果是: 12,12
#include 
#include 
using namespace std;
int main() 
{ 
istream_iterator inputInt(cin);
cout << * inputInt << "," << * inputInt << endl;
return 0; 
}
下面程序运行时,如果输入 12 34 56程序输出结果是: 12,56
#include 
#include 
using namespace std;
int main() 
{ 
istream_iterator inputInt(cin);
cout << * inputInt << "," ;
inputInt ++;
inputInt ++;
cout << * inputInt;
return 0; 
}
来源Guo Wei
 
1 #include <iostream> 2 #include <string> 3 4 using namespace std; 5 template <class T> 6 class CMyistream_iterator 7 { 8 // 在此处补充你的代码 9 public: 10 istream ∈ 11 T now; 12 CMyistream_iterator(istream &c):in(c) { 13 cin >> now; 14 } 15 T operator*() { 16 return now; 17 } 18 void operator++(int) { 19 cin >> now; 20 } 21 }; 22 23 24 25 int main() 26 { 27 int t; 28 cin >> t; 29 while( t -- ) { 30 CMyistream_iterator<int> inputInt(cin); 31 int n1,n2,n3; 32 n1 = * inputInt; //读入 n1 33 int tmp = * inputInt; 34 cout << tmp << endl; 35 inputInt ++; 36 n2 = * inputInt; //读入 n2 37 inputInt ++; 38 n3 = * inputInt; //读入 n3 39 cout << n1 << " " << n2<< " " << n3 << " "; 40 CMyistream_iterator<string> inputStr(cin); 41 string s1,s2; 42 s1 = * inputStr; 43 inputStr ++; 44 s2 = * inputStr; 45 cout << s1 << " " << s2 << endl; 46 } 47 return 0; 48 }
D:简单的SumArray
描述
填写模板 PrintArray,使得程序输出结果是: TomJackMaryJohn 10 不得编写SumArray函数
#include <iostream> #include <string> using namespace std; template <class T> T SumArray( // 在此处补充你的代码 } int main() { string array[4] = { "Tom","Jack","Mary","John"}; cout << SumArray(array,array+4) << endl; int a[4] = { 1, 2, 3, 4}; //提示:1+2+3+4 = 10 cout << SumArray(a,a+4) << endl; return 0; }
输入
无
输出
TomJackMaryJohn
10
样例输入
无
样例输出
TomJackMaryJohn
10
来源Guo Wei
 
1 #include <iostream> 2 #include <string> 3 using namespace std; 4 template <class T> 5 T SumArray( 6 T*s, T*e){ 7 int gap = e - s; 8 T sum=*s; 9 for (int i = 1; i < gap; i++) { 10 sum += *(s + i); 11 } 12 return sum; 13 } 14 int main() { 15 string array[4] = { "Tom","Jack","Mary","John"}; 16 cout << SumArray(array,array+4) << endl; 17 int a[4] = { 1, 2, 3, 4}; //提示:1+2+3+4 = 10 18 cout << SumArray(a,a+4) << endl; 19 return 0; 20 }
E:简单的foreach
描述
编写MyForeach模板,使程序按要求输出 不得编写 MyForeach函数
#include <iostream> #include <string> using namespace std; // 在此处补充你的代码 void Print(string s) { cout << s; } void Inc(int & n) { ++ n; } string array[100]; int a[100]; int main() { int m,n; while(cin >> m >> n) { for(int i = 0;i < m; ++i) cin >> array[i]; for(int j = 0; j < n; ++j) cin >> a[j]; MyForeach(array,array+m,Print); cout << endl; MyForeach(a,a+n,Inc); for(int i = 0;i < n; ++i) cout << a[i] << ","; cout << endl; } return 0; }
输入
多组数据
每组数据第一行是两个整数 m 和 n ,都不超过 50
第二行是m个不带空格的字符串
第三行是 n个整数
输出
对每组数据
第一行输出所有输入字符串连在一起的结果
第二行输出输入中的每个整数加1的结果样例输入
3 4
Tom Mike Jack
1 2 3 4
1 2
Peking
100 200
样例输出
TomMikeJack
2,3,4,5,
Peking
101,201,
来源Guo Wei
函数可以这么传 所以指针也可以缩成一个 type 吗
 
1 #include <iostream> 2 #include <string> 3 using namespace std; 4 //s 5 template<class T1,class T2> 6 void MyForeach(T1* s, T1* e,T2 h ) { 7 int gap = e - s; 8 for (int i = 0; i < gap; i++) 9 h(*(s + i)); 10 } 11 //e 12 void Print(string s) 13 { 14 cout << s; 15 } 16 void Inc(int & n) 17 { 18 ++ n; 19 } 20 string array[100]; 21 int a[100]; 22 int main() { 23 int m,n; 24 while(cin >> m >> n) { 25 for(int i = 0;i < m; ++i) 26 cin >> array[i]; 27 for(int j = 0; j < n; ++j) 28 cin >> a[j]; 29 MyForeach(array,array+m,Print); 30 cout << endl; 31 MyForeach(a,a+n,Inc); 32 for(int i = 0;i < n; ++i) 33 cout << a[i] << ","; 34 cout << endl; 35 } 36 return 0; 37 }
F:简单的Filter
描述
编写Filter模板,使得程序产生指定输出 不得编写 Filter函数
#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; }
输入
无
输出
MikeJackLucy
3,4,5,样例输入
无
样例输出
MikeJackLucy
3,4,5,
来源Guo Wei
 
1 #include <iostream> 2 #include <string> 3 using namespace std; 4 //s 5 template <class T1,class T2> 6 T1* Filter(T1* s, T1* e, T1* to, T2 h) { 7 int p = -1; 8 int gap = e - s; 9 for (int i = 0; i < gap; i++) { 10 if (h(*(s+i))) 11 *(to + (++p)) = *(s+i); 12 } 13 return (to + p+1); 14 } 15 //e 16 bool LargerThan2(int n) 17 { 18 return n > 2; 19 } 20 bool LongerThan3(string s) 21 { 22 return s.length() > 3; 23 } 24 25 string as1[5] = {"Tom","Mike","Jack","Ted","Lucy"}; 26 string as2[5]; 27 int a1[5] = { 1,2,3,4,5}; 28 int a2[5]; 29 int main() { 30 string * p = Filter(as1,as1+5,as2,LongerThan3); 31 for(int i = 0;i < p - as2; ++i) 32 cout << as2[i]; 33 cout << endl; 34 int * p2 = Filter(a1,a1+5,a2,LargerThan2); 35 for(int i = 0;i < p2-a2; ++i) 36 cout << a2[i] << ","; 37 return 0; 38 }
G:你真的搞清楚为啥 while(cin >> n) 能成立了吗?
描述
读入两个整数,输出两个整数 ,直到碰到-1
#include <iostream> using namespace std; class MyCin { // 在此处补充你的代码 }; int main() { MyCin m; int n1,n2; while( m >> n1 >> n2) cout << n1 << " " << n2 << endl; return 0; }
输入
多组数据,每组一行,是两个整数
输出
对每组数据,原样输出 
当碰到输入中出现-1 时,程序结束 
输入中保证会有 -1
样例输入
12 44
344 555
-1
2 3
样例输出
12 44
344 555
来源Guo Wei
 
1 #include <iostream> 2 using namespace std; 3 class MyCin 4 { 5 //s 6 public: 7 bool n; 8 MyCin() { n = 1; } 9 MyCin&operator>>(int &a) { 10 cin >> a; 11 if(a==-1)n=0; 12 return *this; 13 } 14 operator bool() { 15 return n; 16 } 17 //e 18 }; 19 int main() 20 { 21 MyCin m; 22 int n1,n2; 23 while( m >> n1 >> n2) 24 cout << n1 << " " << n2 << endl; 25 return 0; 26 }
其实 operator bool 还是没清楚原理
もう、疲れだ(*´・ω・`)
 
    
 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号