编程练习2——04
来源:互联网 发布:控制鼠标的软件 编辑:程序博客网 时间:2024/06/05 14:17
(1)该数的十进制表示中有且仅有两个相同的数字位;
(2)该数是素数。
分析:先判断是不是素数,之后在该条件下寻找第一个条件。
下面是代码实现:
/**************************************************************
查找介于n1与n2(0<n1<n2<32768)之间所有满足下列条件的整数:
(1)该数的十进制表示中有且仅有两个相同的数字位;
(2)该数是素数。
**************************************************************/
#include <stdio.h>
void Search(int n1, int n2)
{
int i = 0, j = 0, k = 0;
int m = 0, n = 0;
int temp = 0;
int t = 0;
int flag = 0;
int count = 0;
int huanhang = 0;
int Arr[10] = {0};
for (i = n1; i < n2; i++) //先在n1到n2之间找到素数
{
for (j = 2; j < i; j++)
{
if (i % j == 0)
{
flag = 1;
}
}
if (flag == 0)
{
if (i > 10)
{
temp = i;
while (temp) //取出各位数放到数组里
{
Arr[k] = temp % 10;
temp /= 10;
k++;
}
for (m = 0; m < k - 1; m++) //遍历数组,寻找两个相同的数
{
t = Arr[m];
for (n = m + 1; n < k; n++)
{
if (t == Arr[n])
{
count++; //如果相同,计数器记录相同的次数
}
}
}
if (count == 1)
{
huanhang++;
if (huanhang % 10 == 0)
{
printf ("\n");
}
printf ("%6d", i); //一次相同的就是要找的数,并且打印,10个换行
}
count = 0;
k = 0;
}
}
flag = 0;
}
printf ("\n");
}
int main()
{
int n1 = 0;
int n2 = 0;
printf ("please input n1 and n2 :");
scanf ("%d%d", &n1, &n2);
if (n1 > n2 || n1 < 0 || n2 < 0 || n1 >= 32768 || n2 >= 32768) //判断输入的范围是否符合0,32768
{
printf ("error!\n");
return -1;
}
Search(n1, n2);
return 0;
}
- 编程练习2——04
- 编程练习3——04
- 编程练习2——03
- 编程练习2——05
- 编程练习2——06
- 编程练习2——07
- 编程练习2——08
- 编程练习2——09
- 编程练习2——10
- 初学编程——编程练习
- 我的J2ME编程练习(2)——DateField
- 《C++ Primer Plus》——编程练习答案(2)
- GEEK编程练习— —2的次方数
- C++编程练习(2)——椭圆类
- C语言学习历程——编程练习2——04
- 编程练习——红黑树(RedBlackTree)
- 编程练习——伸展树(SplayTree)
- 编程练习——堆heap
- 排序3——堆排序,归并排序,快速排序
- 两种Linux系统安装方式:预装和非预装
- 2054数据结构实验之链表九:双向链表
- Java返回语句-return
- JAVA 第七章集合(五)
- 编程练习2——04
- BZOJ 1597: [Usaco2008 Mar]土地购买【斜率优化】
- 吐了#8
- Sqrt(x)
- Linux21个常用高效命令
- C语言数据结构之普通树篇
- 强化练习6:判断一字符串是否为回文,是返回1,不是返回0,出错返回-1
- Java正则表达式
- ActiveReports报表设计器