现在的位置: 首页 > 综合 > 正文

输出1000以内***数

2014年02月24日 ⁄ 综合 ⁄ 共 1098字 ⁄ 字号 评论关闭

上机内容:C++程序的编写和运行

上机目的:掌握简单C++程序的编辑、编译、连接和运行的一般过程

我的程序:

/*
* 程序的版权和版本声明部分:
* Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作    者:赵玲玲
* 完成日期:2013 年 11 月 10 日
* 版 本 号:v1.0
* 对任务及求解方法的描述部分:
* 输入描述: 无
* 问题描述:熟悉程序的编辑、运行过程
* 程序输出:  无
* 问题分析:略
* 算法设计:略
*/
#include<iostream>
#include<cmath>
using namespace std;
bool isPalindrome(int);                  //函数声明
int reverse(int);
bool isPrime(int);
int main()
{
    int m;
    cout<<"(1)输出1000以内的所有素数"<<endl;
    for(m=2;m<1000;++m)
    {
        if(isPrime(m))
            cout<<m<<'\t';
    }
    cout<<endl<<endl;
    cout<<"(2)输出1000以内的所有回文数"<<endl;
    for(m=2;m<1000;++m)
    {
        if(isPalindrome(m))
            cout<<m<<'\t';
    }
    cout<<endl<<endl;
    cout<<"(3)输出1000以内的所有回文素数"<<endl;
    for(m=2;m<1000;++m)
    {
        if(isPalindrome(m)&&isPrime(m))
            cout<<m<<'\t';
    }
    cout<<endl<<endl;
    cout<<"(4)求1000以内的所有可逆素数"<<endl;
    for(m=2;m<1000;++m)
    {
        if(isPrime(m)&&isPrime(reverse(m)))
            cout<<m<<'\t';
    }
    return 0;
}

bool isPrime(int n)
{
    bool prime=true;
    int k=int(sqrt(n));
    for(int i=2;i<=k;i++)
    {
        if(n%i==0)
        {
            prime=false;
            break;
        }
    }
    return prime;
}

bool isPalindrome(int n)
{
    bool palindrome=false;                         //先默认不是回文数
    if(reverse(n)==n)
        palindrome=true;
    return palindrome;
}

int reverse(int x)
{
    int m=0;
    while(x>0)
    {
        m=m*10+x%10;
        x=x/10;
    }
    return m;
}

运行结果:

心得体会:好吧,我抄的,不过看了深受启发。。。

知识点总结:略

抱歉!评论已关闭.