c++作业7

原创 2016年06月02日 11:54:14

一、特殊三位数

#include<iostream.h>
int fact(int);
int main()
{
	int n,a,b,c,sum;
	n=100;
	while(n<1000)
	{
		c=n%10;
		b=(n/10)%10;
		a=n/100;
		sum=fact(a)+fact(b)+fact(c);
		if(sum==n)
			cout<<n<<endl;
		++n;
	}
	return 0;
}

int fact(int n)
{
	int i, f=1;
	for(i=1;i<=n;++i)
		f=f*i;
	return f;
}


二、素数和回文

#include<iostream.h>       
inline int isPrimer(int n)     
{     
    int i;    
    for(i=2;i<n;i++)    
    {    
        if(n%i==0)    
            break;    
    }    
    if(i==n)    
        return 1;    
    else    
        return 0;    
}    
inline int isPalindrome(int n)     
{    
    int m,a,b,c;    
    b=n%10;    
    a=n/10%10;   
    c=n/100;  
    if(n<10) m=n;  
    else if(n<100) m=b*10+a;  
    else m=b*100+a*10+c;  
    if(m==n)    
        return 1;    
    else    
        return 0;    
}     
inline int fan(int n)    
{    
    int m,a,b,c;    
    b=n%10;    
    a=n/10%10;   
    c=n/100;  
    if(n<10) m=n;  
    else if(n<100) m=b*10+a;  
    else m=b*100+a*10+c;     
    return m;    
}    
int main()    
{    
    int n,i=0,j=0,p=0,q=0,m;    
    int a[300]={0},b[300]={0},c[300]={0},d[300]={0};    
    for(n=2;n<=300;n++)    
    {    
        if(isPrimer(n)==1)    
            a[i++]=n;    
        if(isPalindrome(n)==1)    
            b[j++]=n;    
        if((isPalindrome(n)==1)&&(isPrimer(n)==1))    
            c[p++]=n;    
        if((isPrimer(fan(n))==1)&&(isPrimer(n)==1))    
            d[q++]=n;    
    }    
     cout<<"300以内的所有素数有:"<<endl;  
    for(m=0;m<i;m++)  
    {  
        cout<<a[m]<<"\t";  
        if((m+1)%5==0)  
            cout<<endl;  
    }  
    cout<<endl<<"300以内的所有回文数有:"<<endl;  
    for(m=0;m<j;m++)  
    {  
        cout<<b[m]<<"\t";  
        if((m+1)%5==0)  
            cout<<endl;  
    }  
    cout<<endl<<"300以内的所有回素数有:"<<endl;  
    for(m=0;m<p;m++)  
    {  
        cout<<c[m]<<"\t";  
        if((m+1)%5==0)  
            cout<<endl;  
    }  
    cout<<endl<<"300以内的所有可逆素数有:"<<endl;  
    for(m=0;m<q;m++)  
    {  
        cout<<d[m]<<"\t";  
        if((m+1)%5==0)  
            cout<<endl;  
    }  
    cout<<endl;  
    return 0;  
}  


相关文章推荐

opencv学习(六)书本《学习Opencv》(中文版)第四章的作业答案第二题(opencv3.0.0+VS2012+win7)

显示坐标很简单,但是显示RGB就必须要非常了解IPlImage结构如何获取数据了,书上讲的非常繁杂,下面仔细分析一下IPlImage结构, opencv最重要的结构体是IplImage结构。从本...
  • liulj95
  • liulj95
  • 2015年08月06日 09:41
  • 614

#500-7 [编程作业]3_2 素数和

题目内容: 我们认为2是第一个素数,3是第二个素数,5是第三个素数,依次类推。 现在,给定两个整数n和m,0...

复合材料作业7-2

具体计算代码如下: %时间:2013年12月27日 clear all close all clc global E1 v12 E2 v21 G12 Q11 Q12 Q22 Q66 alpha1...

Win7上eclipse无插件提交Hadoop2.2分布式作业

一直以来,都以为,想在Win上提交hadoop集群的作业,必须得在eclipse上安装hadoop-eclipse-plugin插件才可以提交,但最近与同事交流,发现其实,不一定必须安装hadoop的...

C语言程序设计课后作业7——预习报告

预习1 目标:了解循环的嵌套 提示:参考 C语言循环的嵌套 了解更多信息 预习1题,自拟题,要求应用循环的嵌套语句,并说明程序循环执行的过程 -------------------------...
  • h031522
  • h031522
  • 2013年04月30日 16:18
  • 912

RFID第三次作业[7-2]

调制和解调 调制器用于改变高频载波信号,使得载波信号的振幅、频率或相位与要发送的基带信号相关。解调器的作用则是几条获取到的信号,以重现基带信号。从技术上讲,信号需要调制的因素包括: 1)工作频率...

第一周作业1(LeetCode7)

1. 题目要求Reverse digits of an integer. Example1: x = 123, return 321 Example2: x = -123, return -321...

[Coursera机器学习]Support Vector Machines WEEK7编程作业

1.2 SVM with Gaussian KernelsYou should now complete the code in gaussianKernel.m to compute the Gau...

C语言作业-7-1多项式加法

/* ~scanf("%d%d",&x,&y); 思路:0、先读入两组数,分别存到连个数组中; 1、将两个数组按照算法要求转变成一个数组 2、分三大类进行输出:0)a[i](i...

JSP+Servlet培训班作业管理系统[7] -Mysql数据库设计

从本篇开始,速度会变快一点,然后注释会精简一点,但是代码会贴的全一点。本篇来实现JSP+Servlet培训班作业管理系统的数据库部分。首先通过Navicat的ER图标来阅览整个结构:具体说明如下:sy...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c++作业7
举报原因:
原因补充:

(最多只允许输入30个字)