c语言判断是否素数程序代码_C 语言

复制代码 代码如下:

#include <stdio.h>

bool isPrimeNum(int x)
{
    if (x == 1)
        return false;
    else if (x <= 0)
        return false;
    else if (x == 2)
        return true;
    else
    {
        for (int i = 2; i < x; i++)
        {
            if (x%i == 0)
                return false;
        }
        return true;

    }
}

int main(void)
{
    int x;
    char ch;
    do{
    printf("请输入一个大于1的自然数:\n");
    scanf("%d", &x);
    if (isPrimeNum(x) == false)
        printf("%d不是素数\n",x);
    else if (isPrimeNum(x) == true)
        printf("%d是素数\n",x);
    printf("是否继续(y/n):\n");
    scanf("%c", &ch);
    }while ('y'== ch || 'Y' == ch);
    return 0;
}

但是,运行的时候,出现了一个问题.

本来写do...while是为了省事,重复判断.但是,却愣是不起效果.

后来,修改了一下:

复制代码 代码如下:

#include <stdio.h>

bool isPrimeNum(int x)
{
    if (x == 1)
        return false;
    else if (x <= 0)
        return false;
    else if (x == 2)
        return true;
    else
    {
        for (int i = 2; i < x; i++)
        {
            if (x%i == 0)
                return false;
        }
        return true;

    }
}

int main(void)
{
    int x;
    char ch;
    do{
    printf("请输入一个大于1的自然数:\n");
    scanf("%d", &x);
    if (isPrimeNum(x) == false)
        printf("%d不是素数\n",x);
    else if (isPrimeNum(x) == true)
        printf("%d是素数\n",x);
    printf("是否继续(y/n):\n");
    scanf(" %c", &ch);//在这里加一个空格
    }while ('y'==ch || 'Y' == ch);
    return 0;
}

这样,问题就神奇地解决了.

再后来,再这么改:

复制代码 代码如下:

#include <stdio.h>

bool isPrimeNum(int x)
{
    if (x == 1)
        return false;
    else if (x <= 0)
        return false;
    else if (x == 2)
        return true;
    else
    {
        for (int i = 2; i < x; i++)
        {
            if (x%i == 0)
                return false;
        }
        return true;

    }
}

int main(void)
{
    int x;
    char ch;
    do{
    printf("请输入一个大于1的自然数:\n");
    scanf("%d", &x);
    if (isPrimeNum(x) == false)
        printf("%d不是素数\n",x);
    else if (isPrimeNum(x) == true)
        printf("%d是素数\n",x);
    printf("是否继续(y/n):\n");
    scanf("\n%c", &ch);//在这里加一个换行符 '\n'
    }while ('y'==ch || 'Y' == ch);
    return 0;
}

也没问题.

所以,总结一下,问题出现在我们在输入数字按下回车的似乎,'\n'还保存在输入流中

因此,看第一个代码:

复制代码 代码如下:

int main(void)
{
    int x;
    char ch;
    do{
    printf("请输入一个大于1的自然数:\n");
    scanf("%d", &x);
    if (isPrimeNum(x) == false)
        printf("%d不是素数\n",x);
    else if (isPrimeNum(x) == true)
        printf("%d是素数\n",x);
    printf("是否继续(y/n):\n");
    scanf("%c", &ch);  //因为 '\n'还在输入流中  所以 就变成了  ch = '\n';
    }while ('y'==ch || 'Y' == ch);  // 'y' != '\n'  && 'Y' != '\n';
    return 0;   //因此程序就return了
}

另外,也是可以使用fflush(stdin)清空输入缓存区.

复制代码 代码如下:

#include <stdio.h>

bool isPrimeNum(int x)
{
    if (x == 1)
        return false;
    else if (x <= 0)
        return false;
    else if (x == 2)
        return true;
    else
    {
        for (int i = 2; i < x; i++)
        {
            if (x%i == 0)
                return false;
        }
        return true;

    }
}

int main(void)
{
    int x;
    char ch;
    do{
    printf("请输入一个大于1的自然数:\n");
    scanf("%d", &x);
    if (isPrimeNum(x) == false)
        printf("%d不是素数\n",x);
    else if (isPrimeNum(x) == true)
        printf("%d是素数\n",x);
    printf("是否继续(y/n):\n");
    fflush(stdin);  //清空输入缓存区
    scanf("%c", &ch);
    }while ('y'==ch || 'Y' == ch);
    return 0;
}

时间: 2024-08-03 23:48:11

c语言判断是否素数程序代码_C 语言的相关文章

基于C语言实现的扫雷游戏代码_C 语言

本文详细讲述了基于C语言实现的扫雷游戏代码,代码中备有比较详细的注释,便于读者阅读和理解.希望对学习游戏开发的朋友能有一点借鉴价值. 完整的实例代码如下: /* 模拟扫雷游戏 */ #include <graphics.h> #include <math.h> #include <stdio.h> #include <dos.h> #include <stdlib.h> #include <conio.h> #include <

基于C语言实现的迷宫游戏代码_C 语言

本文实例讲述了基于C语言实现迷宫游戏的方法,代码备有较为详尽的注释,便于读者理解.通过该游戏代码可以很好的复习C语言的递归算法与流程控制等知识,相信对于学习游戏开发的朋友有一定的借鉴价值. 完整的实例代码如下: #include <graphics.h> #include <stdlib.h> #include <stdio.h> #include <conio.h> #include <dos.h> #define N 20/*迷宫的大小,可改

C语言 数据结构之链表实现代码_C 语言

前言 最近在复习数据结构的相关知识,感觉在初学的时候还是有很多东西没有掌握,不过现在终于算是搞得比较有头绪了,所以就在写出来和大家一起分享! 什么是链表 简单的说,链表就是由多个结点离散分配,彼此通过指针相连,每个结点只有一个前驱结点和后继结点.首节点无前驱结点,为结点无后继结点的一种存储结构. 链表的结构 头结点:链表的第一个有效结点前面的结点,头结点并不存放有效数据,也就是数据域为空,加头结点的主要目的是为了方便链表的操作. 首节点:链表的第一个有效结点,结点包含数据域和指针域. 尾结点:尾

C语言合并排序及实例代码_C 语言

归并排序也称合并排序,其算法思想是将待排序序列分为两部分,依次对分得的两个部分再次使用归并排序,之后再对其进行合并.仅从算法思想上了解归并排序会觉得很抽象,接下来就以对序列A[0], A[l]-, A[n-1]进行升序排列来进行讲解,在此采用自顶向下的实现方法. 操作步骤如下: (1)将所要进行的排序序列分为左右两个部分,如果要进行排序的序列的起始元素下标为first,最后一个元素的下标为last,那么左右两部分之间的临界点下标mid=(first+last)/2,这两部分分别是A[first

用C++实现队列的程序代码_C 语言

C++实现队列,如有不足之处,还望指正 复制代码 代码如下: // MyQueue.cpp : 定义控制台应用程序的入口点.//实现链式队列(queue),包括一个头结点.队列操作包括在队头出队(pop).在队尾入队(push).//取得队头元素(front_element).取得队尾元素(back_element).队列元素个数(size).//队列是否为空(empty).#include "stdafx.h"#include <iostream>using namesp

C++键盘记录程序代码_C 语言

本文实例讲述了C++键盘记录程序.分享给大家供大家参考.具体分析如下: 主程序如下: 就是基于对话框的框架,加个个OnHookKey函数, 复制代码 代码如下: long CMainDialog::OnHookKey(WPARAM wParam, LPARAM lParam)   //处理自定义消息  {      char szKey[80]={0};      GetKeyNameText(lParam, szKey, 80);      CString strItem;      strI

C语言 实现N阶乘的程序代码_C 语言

代码如下所示: 复制代码 代码如下: #include <stdio.h>#include <stdlib.h>#define N 10 //算N的阶乘int main(){       //数组   1位 1!    int ary[N] = {1, 1};    int i, j;    for (i = 2; i <= N; i++)    {        //各个下标的阶乘,第0位下标是位数,所以从第1位开始        for (j = 1; j <= a

使用OpenGL实现3D立体显示的程序代码_C 语言

由于左眼和右眼观看显示器的角度不同,利用这一角度差遮住光线就可将图像分配给右眼或者左眼,经过大脑将这两幅由差别的图像合成为一副具有空间深度和维度信息的图像,从而可以看到3D图像.完整的实现代码如下所示: 复制代码 代码如下: #include "stdafx.h"#include "GL/glut.h"#include "stdlib.h"#include "stdio.h"#include "math.h"

C 语言插入排序算法及实例代码_C 语言

插入排序是排序算法的一种,它不改变原有的序列(数组),而是创建一个新的序列,在新序列上进行操作. 这里以从小到大排序为例进行讲解. 基本思想及举例说明 插入排序的基本思想是,将元素逐个添加到已经排序好的数组中去,同时要求,插入的元素必须在正确的位置,这样原来排序好的数组是仍然有序的. 在实际使用中,通常是排序整个无序数组,所以把这个无序数组分为两部分排序好的子数组和待插入的元素.第一轮时,将第一个元素作为排序好的子数组,插入第二个元素:第二轮,将前两个元素作为排序好的数组,插入第三个元素.以此类