|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
这个为什么判断不出来是否重复了呢,求教育
- [code][code][code]#pragma once
- int px(int hq[], int ind, int c)
- {
- int i, j, temp;
- if (c == 0)
- {
- for (i = 0; i < ind - 1; i++)
- {
- for (j = 0; j < ind - 1 - i; j++)
- {
- if (hq[j] > hq[j + 1])[code]#pragma once
- int pd(int hq[])
- {
- int i, j, temp;
- for (i = 0; i < 6 - 1; i++)
- {
- for (j = 0; j < 6 - 1 - i; j++)
- {
- if (hq[j] ==hq[j + 1])
- {
- sc(hq);
- }
- }
- }
- }
复制代码
{
temp = hq[j];
hq[j] = hq[j + 1];
hq[j + 1] = temp;
}
}
}
}
else
{
for (i = 0; i < ind - 1; i++)
{
for (j = 0; j < ind - 1 - i; j++)
{
if (hq[j] < hq[j + 1])
{
temp = hq[j];
hq[j] = hq[j + 1];
hq[j + 1] = temp;
}
}
}
}[/code][/code][/code][/code]- #include<stdio.h>
- #include<time.h>
- #include<stdlib.h>
- #include "px.h"
- #include"pd.h"
- int sc(int hq[]);
- int main()
- {
- srand(time(NULL));
- int hq[6];
- int i;
- sc(hq);
- pd(hq);
- px(hq, 6, 0);
- for (i = 0; i < 6; i++)
- {
- printf("%d\t",hq[i]);
- }
- }
- int sc(int hq[])
- {
- int i;
- for (i = 0; i < 6; i++)
- {
- hq[i] = rand() % 33 + 1;
- }
- }
复制代码
这段代码中没有对重复数字进行判断,因此无法判断是否存在重复数字。
在你的代码中,可以在sc函数中添加一个while循环来确保生成的数字不会重复。例如,可以这样修改:
- int sc(int hq[]) {
- int i, j, flag;
- for (i = 0; i < 6; i++) {
- flag = 1;
- while (flag) { // 循环直到生成一个不重复的数字
- hq[i] = rand() % 33 + 1;
- flag = 0;
- for (j = 0; j < i; j++) {
- if (hq[i] == hq[j]) {
- flag = 1;
- break;
- }
- }
- }
- }
- }
复制代码
在这个修改后的sc函数中,我们添加了一个while循环来确保生成的数字不会重复。在循环中,首先生成一个随机数,然后检查该数字是否与前面生成的数字重复。如果重复了,就继续生成一个随机数,直到生成一个不重复的数字为止。这样就可以确保生成的6个数字不会有重复了。
|
|