双色球红球蓝球组合次数计算及输出每组组合数

#include <stdio.h>

#define N 6

#define M 34

int main(void)

{

int a, b, c, d, e, f; //七个红球变量

int i, j,n = 0; //循环变量,n为组合次数

int num[N]; //存储计算出的每组组合数

FILE *pfile = NULL;

if (!(pfile = fopen("c.text", "w"))) //以写入方式打开文件

{

printf("打开文件失败!");

exit(1);

}

//开始计算组合数

for (a = 1; a < (M - 5); a++)

{

for (b = 2; b < (M - 4); b++)

{

for (c = 3; c < (M - 3); c++)

{

for (d = 4; d < (M - 2); d++)

{

for (e = 5; e < (M-1); e++)

{

for (f = 6; f < M; f++)

{

if (a < b&&a < c&&a < d&&a < e&&a < f&&b < c&&b < d&&b < e&&b < f&&c < d&&c < e&&c < f&&d < e&&d < f&&e < f&&a != b && a != c && a != d && a != e && a != f && b != c && b != d && b != e && b != f && c != d && c != e && c != f && d != e && d != f && e != f) //判断每个数从左到右,依小到大排列并且每个数不重复

{

printf("%d %d %d %d %d %d\n", a, b, c, d, e, f); //输出每组组合数

n++; //累计次数

num[0] = a;

num[1] = b;

num[2] = c;

num[3] = d;

num[4] = e;

num[5] = f;

fprintf(pfile, "%d %d %d %d %d %d\n", num[0],num[1],num[2],num[3],num[4],num[5]);//文件输出

}

}

}

}

}

}

}

fclose(pfile); //关闭文件

pfile = NULL;

printf("双色球红球组合次数为:%d\n", n); //输出总次数

printf("\n");

printf("存储文件成功!按任意键读取文件信息!");

printf("\n");

getch(); //暂停等待按任意键

if (!(pfile = fopen("c.text", "r"))) //以读取方式打开文件

{

printf("打开文件失败!");

exit(1);

}

//开始读取文件信息并写入num数组

for (j = 0; j < n; j++)

{

fscanf(pfile, "%d %d %d %d %d %d", &num[0], &num[1], &num[2], &num[3], &num[4], &num[5]); //文件输入

printf("%d %d %d %d %d %d\n", num[0], num[1], num[2], num[3], num[4], num[5]); //输出文件信息

}

fclose(pfile); //关闭文件

pfile = NULL;

printf("读取文件成功!按任意键退出!\n");

getch(); //暂停等待按任意键

exit(1);//退出程序

return 0;

}

猜你喜欢

转载自blog.csdn.net/JOKERHB/article/details/82503010
今日推荐