c语言全排列模板

作者&投稿:辉科 (若有异议请与网页底部的电邮联系)

一个C语言全排列的算法。 比如,输入3,则将123的全排列全部输出:123...
include main(){ int a1,a2,a3,a4,a5,a6,a7,a8,a9,n,t=0;scanf("%d",&n);for(a1=1;a1<=n;a1++)if(n==1){printf("%d\\n",a1);t=t+1;} else for (a2=1;a2<=n;a2++)if(a2!=a1){if(n==2) {printf("%d%d\\n",a1,a2);t=t+1;} else for (a3=1;a3<=n;a3+...

全排列用C语言实现
include<stdio.h> include<string.h> char a[20];int lenth;long count=0;void main(){void move(int,int);int i,j=0;printf("input:");gets(a);lenth=strlen(a);for(i=0;i<lenth;i++)move(j,i);\/\/move a[i] to the front of a[j];printf("\\ntotal=%d\\n",count);} v...

如何用C语言编写1234的全排列
include <stdio.h> void main(){ int i=0,j=0,k=0,l=0,count=0;for(i=1;i<=4;i++){ for(j=1;j<=4;j++)if(j!=i)for(k=1;k<=4;k++)if(k!=i&&k!=j)for(l=1;l<=4;l++)if(l!=i&&l!=j&&l!=k){ count++;printf("\\n\\t第%2d个 %d %d %d %d",coun...

c语言全排列
1、首先看最后两个数4, 5。 它们的全排列为4 5和5 4, 即以4开头的5的全排列和以5开头的4的全排列。由于一个数的全排列就是其本身,从而得到以上结果。2、再看后三个数3, 4, 5。它们的全排列为3 4 5、3 5 4、 4 3 5、 4 5 3、 5 3 4、 5 4 3 六组数。即以3开头的和4...

C语言将ABCD全排列 应该怎么写?
四个字母,全排列,则建立四重循环,当四个循环变量互不相同时,输出四个循环变量值,即可得结果!

a,b,c,d全排列C语言,C++,排列组合
int main(){ char a[4] = {'a','b','c','d'};\/\/定义字符数组 int i , j , k , l , cnt = 0;\/\/定义循环变量及当前为第cnt个组合 for(i = 0 ; i < 4 ; i++){\/\/a的所有可能位置 for(j = 0 ; j < 4 ; j++){\/\/b的所有可能位置 if(j != i){\/\/如果b的...

...用c语言实现1,5,6,11,14,15,16,18,19的全排列,并且要求14要在11...
include<stdio.h> void main(){int a,b,c,d,e,f,g,h,i,count=0;int num[9],shu[9];int fun(int s[]);int max(int p,int q);for(a=0; a<9;a++)for(b=0; b<9;b++)for(c=max(a,b)+1;c<9;c++)for(d=0; d<9;d++)for(e=d+1; e<9;e++)for...

c语言全排列
void Find(int depth)\/\/递归式回溯法生成全排列 { if (depth==m){ int i;for (i=0;i<depth;i++) putchar(map[stack[i]]);putchar('\\n');} else { int i;for (i=0;i<n;i++)if (count[i]){ stack[depth]=i;count[i]--;Find(depth+1);count[i]++;} } } main(){...

C语言编写一个程序,真心求教:1.2.3.4四个数,能组合成多少个不同的三位 ...
将1234依次存入一个char型数组内,自定义一个全排列列函数进行4个数字的全排列运算,但每次输出时只取后3位即可达到目的。代码如下:include "stdio.h"void myfun(char *p,int i,int n){\/\/自定义全排列函数int j,t;if(i-n)for(j=i;j<=n;j++){t=p[i],p[i]=p[j],p[j]=t;myfun...

C语言怎么实现有重复元素的全排列?
void perm(char *s, int n, int idx) { \/\/ 回溯产生字符串全排列 if (idx == n) { \/\/ 已排列到字符串结尾 res[num] = (char *)malloc(sizeof(char) * (n + 1));\/\/printf("%s\\n", s); \/\/ 输出当前排列 strcpy(res[num], s); \/\/ 保存当前排列 num++; \/\/ 排列总数加...

虿韩13945393112问: 用c语言实现 ABCDE按照全排列输出所有结果 -
金城江区脑脉回答: #include <stdio.h> #include <stdlib.h> void main() {char i,j,k,m,n;for(i='A';i<='E';i++)for(j='A';j<='E';j++)for(k='A';k<='E';k++)for(m='A';m<='E';m++)for(n='A';n<='E';n++)if(i!=j&&i!=k&&i!=m&&i!=n&&j!=k&&j!=m&&j!=n&&k!=m&&k!=n&&m!=n)...

虿韩13945393112问: 用c语言编写全部排列 -
金城江区脑脉回答: void chang(char str[],int m) /*定义循环左移函数(我没有用左移函数)*/{int i,j;char temp=str[0];for (i=0;i<m;i++) str[i]=str[i+1];str[i]=temp;} void pai(char str[],int m,int n) /*定义全排列函数*/ {int k;void chang(char str[],int m);if (m<n) /* 定 义 递 ...

虿韩13945393112问: 急!!!如何用C语言编写打出1~n个数的全排. -
金城江区脑脉回答: 递归,比较简单,10个数全排如下#include<stdio.h> void swap(int k,int i,int a[]) { int t; t=a[k]; a[k]=a[i]; a[i]=t; } void pailie(int a[],int i,int n) {int k,t; if(i==n) { for(t=0;t<n;t++) printf("%3d",a[t]); printf("\n"); } elsefor(k=i;k<n;k++) { swap(i,k,a); pailie(a...

虿韩13945393112问: c语言 给出一个数怎样输出该数的全排列 -
金城江区脑脉回答: 递归法:设输入的数为n,N={1,2,...n} 不断选择数字i,把i从N中剔除,直到N为空集即可 代码如下:#include <stdio.h>#include <stdlib.h>#include <string.h> int N; bool *mark; int *output, pos = 0; void AddNumber(int i) {bool finish = true; mark[i] = ...

虿韩13945393112问: 如何用C语言编写1234的全排列 -
金城江区脑脉回答: #include <stdio.h> void main() {int i=0,j=0,k=0,l=0,count=0;for(i=1;i<=4;i++){for(j=1;j<=4;j++)if(j!=i)for(k=1;k<=4;k++)if(k!=i&&k!=j)for(l=1;l<=4;l++)if(l!=i&&l!=j&&l!=k){ count++;printf("\n\t第%2d个 %d %d %d %d",count,i,j,k,l);}}putchar('\n'); }

虿韩13945393112问: 一个C语言全排列的算法. 比如,输入3,则将123的全排列全部输出:123,132,213,231 -
金城江区脑脉回答: #include main() { int a1,a2,a3,a4,a5,a6,a7,a8,a9,n,t=0; scanf("%d",&n); for(a1=1;a1<=n;a1++) if(n==1){printf("%d\n",a1);t=t+1;}else for (a2=1;a2<=n;a2++)if(a2!=a1) {if(n==2) {printf("%d%d\n",a1,a2);t=t+1;} else for (a3=1;a3<=n;a3++)if(...

虿韩13945393112问: c语言作业,输出四个数A,B,C,D的全排列 -
金城江区脑脉回答: #include <iostream> #include <stdio.h> #include <algorithm> using namespace std; int main() {int num[4]={1,2,3,4};do{printf("%c,%c,%c,%c\n",num[0]+'A'-1,num[1]+'A'-1,num[2]+'A'-1,num[3]+'A'-1);}while(next_permutation(num,num+4));...

虿韩13945393112问: C 语言 全排列
金城江区脑脉回答: #include<stdio.h>/*这两个库函数是习惯性的加上去的^_^.*/ #include<stdlib.h> #define ISPRINT/*是否打印结果的标志*/ #define MAX 200/*最大的数*/ unsigned int *_NUM;/*用于存放一条结果的数组指针*/ char *_NUMFLAG;/*用于存放是否已...

虿韩13945393112问: C语言递归问题(全排列) -
金城江区脑脉回答: 可以输出所有的排列,i和n表示排列的起始点和终止点比如说要排列"abcd"起点就是0,终点是3,perm(“abcd”,0,3)就可以了.

虿韩13945393112问: c语言求全排列 -
金城江区脑脉回答: 用迭代算法简单些, 就是速度慢许.算法为: 为求1 ~ n个整数的函数 permutation, * 如果n = 2, 只有两种排列方式, 即 (1, 2) (2, 1)* 迭代计算1 ~ n-1个整数的全排列* 将n插入所得到的1 ~ n-1的全排列的任意位置得到1 ~ n的全排列.


本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网