原题目是“有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?”
后增加了条件:输入4个数字,可重复相同数字。
#include "pch.h"
#include <iostream>
#include <algorithm>
using namespace std;
//【模板类】实现——将得到的4个数字,组合成不含重复数字的3位数。
template<typename T>
void Karray(T& a,T& b,T& c,T& d) {
T temp1=0, temp2=0, temp3=0, TEMP=0;//类型为T,随主函数参而变
int temp_array[] = { a,b,c,d };
int tem[24];//——
int m = 0;//用于计数
for (int i = 0; i < 4; i++) { //first
temp1 = temp_array[i];
for (int j = 0; j < 4; j++) { //second
temp2 = temp_array[j];
for (int k = 0; k < 4; k++) { //thrid
temp3 = temp_array[k];
if (temp1 != temp2 && temp1 != temp3 && temp2 != temp3) { //排除重复数字
tem[m] = 1