马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 i也不知道 于 2019-10-11 14:12 编辑 #include <stdio.h>
#define TRUE 1
#define FALSE 0
typedef int BOOL;
int main()
{
BOOL digit_seen = { 0 };
int digit;
long int n;
printf("Enter anumber:");
scanf_s("%ld", &n);
while (n>0)
{
digit = n % 10;
if (digit_seen[digit])
{
break;
}
digit_seen[digit] = TRUE;
n /= 10;
}
if (n > 0)
{
printf("Repeated digit \n\n");
}
else
{
printf("No repeated digit\n\n");
}
return 0;
}
采用布尔型值的数组跟踪数中出现的数字。
名为digit_seen的数组有十个可能的数字,数组元素的下标索引从0到9.最初的时候,每个数组元素都为0(假的)。
当给出数n时,程序一次一个的检查n的数字,并且把每次的数字存储在变量digit中,然后用这个数字作为数组digit_seen的下标索引。
如果digit_seen[digit]为真,那么表示digit至少在n中出现了两次。
另一方面,如果digit_seen[digit]为假,那么表示digit之前从未出现过,程序会把digit_seen[digit]设置为真并继续执行。
|