c++随机选出4个元素排列组合

供稿:hz-xin.com     日期:2025-01-15
c++随机选取组合

#include #include using namespace std;void FillArr(int* pnArr, int *pnDesArr, int i){//取0-10之间的一个随机数int m = rand() % 11;int temp = pnArr[m];bool bIsRepeat = false;//判断随机取得的一个数是否与前面取得的数重复for (int j = 0; j < i; ++j){if(pnDesArr[j] == temp){bIsRepeat = true;break;}}//如果重复则重新随机取一个数if (bIsRepeat){FillArr(pnArr, pnDesArr, i);}//如果不重复就将这个随机取得的数填充到目标数组中else{pnDesArr[i] = temp;}}int main(){int nArr[11] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11};int nDesArr[9] = {0, 0, 0, 0, 0, 0, 0, 0, 0};srand((unsigned)time(NULL));for (int i = 0; i < 9; ++i){FillArr(nArr, nDesArr, i);cout<<nDesArr[i]<<endl;}getchar();return 0;}


思路:随机选择 4 个元素比较简单,但是要达到产生所有可能的的排列,不能用这种方法。比较好的方法是:将全部的排列列出并编号,然后随机选择这些编号。具体代码要些时间写,如果有需要,等我有空的时候可以写出来给你。

c++用四个sorting来排列数组怎么做?在线等,急
include "stdafx.h"include<iostream> using namespace std;void bubbleSort(int[], int);void insertSort(int[], int);void selectSort(int[], int);void mergeSort(int[], int, int, int[]);int main(){ int number = 0;cout << "enter the number of elements in tht array: ";c...

编程输出从1,2,3,4,5,6中任选3个数组成的所有组合
} \/\/ 计算组合数 C(m,n)int cmn(int m,int n){ if(m>n){ return 0;} else { return fact(n)\/fact(m)\/fact(n-m);} } void permutationAndCombination (\/\/ 基本参数 int data[],int dataSize,int selectNum,\/\/ 递归用到的参数 int start,int flag[],int count,\/\/ 选择排列的...

从1~9取4个数字(不重复)经行排列组合,且其中不含4,将其结果输出到txt文 ...
include <stdio.h>#include <stdlib.h>char array[] = "12356789";#define N 8#define M 4int queue[N] = {0};int top = 0;int flag[M] = {0};char s[4]={0};FILE *p;p = fopen("1.txt","w");void perm(int s1, int n){ int i; if (s1 > n) { ...

C\/C++语言 从33个数中选6个排列组合
组合:从n个不同元素中取r个不重复的元素组成一个子集,而不考虑其元素的顺序,称为从n个中取r个的无重组合,例如OR = {1,2,3,4}, n = 4, r = 3则无重组合为:{1,2,3}; {1,2,4}; {1,3,4}; {2,3,4}.include <stdio.h> include <stdlib.h> include <iostream.h> in...

C++中的排列组合
const int N=21;using namespace std;int issushu(long num){ for(long i=2;i<=sqrt(num);i++)if(num%i==0)return 0;return 1;} long totalsum(long a[],int n){ long sum=0;for(int i=0;i<n;i++)sum+=a[i];return sum;} int main(){ cout<<endl<<"please input ...

输出数组{1,2,3,4,5,6}中六个数的所有随机组合
int a[6] = {1, 2, 3, 4, 5, 6};int aOutput[6] = {0};bool aUsed[6] = {false};void Print(int nDepth);int main(){ Print(0);return 0;} void Print(int nDepth){ if (nDepth == 6) { for (int i = 0; i < 6; i++)cout << aOutput[i];cout << endl...

用java程序编写,1234这四个数进行排列组合,
import java.util.ArrayList;import java.util.List;public class Order { public static String[] str = {"1","2","3","4"};public static void main(String[] args){ System.out.println("---");for(String s:str){ System.out.println(s+" , ");} System.out.println("---"...

数字1、2、3、4,任意组合排列,算出所有的可能,怎么弄?
如果需要显示更多数字的组合可能,可以选择修改list[]数组中元素的个数即可。\/ include <stdio.h>#include <conio.h> int n = 0;void swap(int *a, int *b){ int m;m = *a;a = *b;b = m;} void perm(int list[], int k, int m, FILE *fp){ int i;if(k > m){ for(i...

c# 一个数组元素排列组合
从一个集合里取出N个元素组合,当N<=3时,用循环表述比较方便。string[] values = { "A", "B", "C", "D", "E" };Console.WriteLine("取2个组合:");for (int i = 0; i < values.Length - 1; i++){for (int j = i + 1; j < values.Length; j++)Console.WriteLine(...

C语言编写一个程序,真心求教:1.2.3.4四个数,能组合成多少个不同的三位 ...
这是一个简单的排列组合,三位数,每位都有四个数字可以选择,所以就是4*4*4种组合,具体如下,不明白的话可以给你讲讲 include <stdio.h> int main(){ int i,a,b,c;int num;i = 1;for(a = 1; a <= 4; a++) \/\/百位循环 for(b = 1; b <= 4; b++)\/\/十位循环 for(c = ...