我正在构建一个程序,它使用值的 ascii 表随机生成一个密码,并且每个字符只能包含一个。它生成一个 8 个字符长的密码。
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#define SIZE 10
char Charactor(char x);
void Check(char* y);
int main()
{
char string[SIZE];//defines varriables
char* point;
point=&string[SIZE];
srand(time(NULL));
for (int i=0;i<SIZE-1;i++)//empties out the string
{
string[i]='\0';
}
for (int i=0;i<SIZE-2;i++)//randomizes a char for each space in the string
{
string[i]=Charactor(*point);
}
Check(point);/checks the string for duplicated values
printf("%s\n",string);//prints string on screen
}
char Charactor(char x)
{
int rnd=0;
rnd=rand()%2;//chooses char or number using ascii
if (rnd==0)
{
rnd=rand()%10+48;
}
else
{
rnd=rand()%26+65;
}
x=(char)rnd;
return x;
}
void Check(char* y)
{
int run=0;
for (int i=0; i<SIZE-2;i++)
{
for (int x=0; x<SIZE-2; x++)
{
if (y[i]==y[x] && run=0)
{
run++;
continue;
}
else
{
y[i]='\0';
y[i]=Charactor(*y);
}
}
}
return;
}
有了这些更改,代码现在正在运行,我只需要弄清楚如何更改正确的值,这样我就没有任何重复。
最佳答案
修复:
char* point =&string[0];//让它指向第一个元素
因为你的 Character(*point);
实际上没有做任何基于 *point
的事情,后来你使用了 Check(point);
可能从字符串的开头开始扫描。
和
if (y[i]==y[x] && run==0)
^^Use Equality check
您不能将 y[i]==y[x] && run
的 boolean
结果修改为零。
注意:
但是 if (y[i]==y[x] && (run=0) )
不会引发此错误。
关于c - 使 y[i] 成为 C 中的可修改变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18663581/