2013级C++第11周项目——函数的定义与调用

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759


【项目1-调用函数输出星号图】

  这一组的练习意在通过调用函数输出星号图,体会与理解函数的工作过程,并为其后编制自定义函数实现特定功能。

  (1)补充完下面的程序,使程序输出星号图:

#include <iostream>
using namespace std;
void printstars(int m) //定义能输出一行m个星号的函数
{  
  for (int j=1; j<=m; ++j)
    cout<<'*';
}
int main( )
{ 
  int n=6; //n代表要输出的行数
  for(i=1; i<=n; ++i)
    {
        //请在下面写上调用printstars函数的语句,使程序输出右图
        ______________________;
        cout<<endl;
    }
  return 0;
} 


  (2)根据main函数中对printchs函数的调用,以及printchs的功能要求,编写printchs函数。

//调用函数printchs输出星号图
#include <iostream>
using namespace std;
//在下面写printchs函数的定义,功能是输出一行若干个指定字符
 
int main( )
{ 
  int n=6; //n代表要输出的行数
  int i;
  //通过在下面的循环里调用printchs函数,输出右面的图
  for(i=1; i<=n; ++i)
  {
    printchs(n-i,' ');
    printchs(2*i-1,'*') ;
    cout<<endl;
  }
  return 0;
} 

  ( 3 )在由多个函数构成的程序中,程序员常用的做法是, main() 函数先定义,其他自定义函数后定义,这时必须在 main() 函数前声明自定义的函数(请详读教材 4.4.3 小节)。按这个要求,重写上面任务 2 中的程序。

  (4)利用任务2中定义的printchs函数,再实现以前写过的其他星号图,体会定义函数带来了的好处。

 

【项目2-求最大公约数】输入两个数,并求出其最大公约数

#include <iostream>
using namespace std;
//自定义函数的原型(即函数声明)
 
int main()
{
  int a,b,g;
  cin>>a>>b;
  g=gcd(a,b);
  cout<<"最大公约数是: "<<g;
  return 0;
}
 
int gcd(int x,int y) //定义用于求两数的最大公约数的函数。函数只管求值,不管输出,输出由main完成。

{
 
}

  如果算法方面有问题,请参考:

  


【项目2扩展-求四数的最大公约数】

  在上面程序基础上,增加函数gcds函数的声明和定义,实现求4数最大公约数的功能

int gcds(int x,int y,int z,int w)   //调用gcd()求四数的最大公约数
{
 
}

  提示:( 1 )既然在项目 2 gcd 函数已经实现了求两数最大公约数的功能, gcds 中可以调用 gcd ——先分别求出前两数、后两数的最大公约数,再求出最大公约数的最大公约数;( 2 )修改 main 函数,以完成对新新定义的函数的“测试”

 

【项目3-回文、素数】

  (1)编制一个函数reverse,返回给定数据的“反序数”,例如输入1234,输出4321。请编制reverse函数,在下面代码的基础上补充相关的部分,实现要求的功能。

int main()
{
    int m,n;
    cin>>m;
    n=reverse(m);
    cout<<n<<endl;
}
int reverse(int x)//自定义函数只管求值,不管输出。输出由main函数完成。

{
}

  如果算法方面有问题,请参考:

  

  (2)编制isPalindrome(),用于判断参数是否是回文数——回文数,即从前往后读和从后往前读都一样的数,如1221121都是回文数,而1231123都不是回文数。请编制isPalindrome(函数,在下面代码的基础上补充相关的部分,实现要求的功能。

int main()
{
    int m;
    cin>>m;
    if(isPalindrome(m))
        cout<<m<<"是回文数,噢耶!"<<endl;
    else
        cout<<m<<"不是回文数。回文有什么好!"<<endl;
    return 0;
}
 
bool isPalindrome(int n)
{
}

  ( 3 )编制一个返回值为 bool 型的函数 isPrimer() ,用于判断参数是否为素数(是素数返回 true ,否则 false ),自编 main 函数用于测试;

int main()
{
    //此处写代码,能够调用isPrimer函数完成“测试”
}
 
bool isPrimer(int n)
{
}

  ( 4 )编制 main 函数,调用上面定义的 3 个函数,完成

  • 输出1000以内的所有素数。
  • 输出1000以内的所有回文数。
  • 输出1000以内的所有回文素数。
  • 若一个素数的反序数仍为素数,则称它为可逆素数。求10000以内的所有可逆素数。

 【项目4-特殊三位数】

  请输出满足条件n=a!+b!+c!的所有三位数n,其中,abc分别是n的百、十、个位数。要求用自定义函数实现求阶乘。

  参考程序段:

int  main()
{
} 
long fac(int n)
{
}

【项目 4 拓展(选做) - 求组合数】

  求组合数公式为:

  

  编一程序,输入mn的值,求组合数。要求分别定义求阶乘和求组合的函数,求组合数的函数调用求阶乘的函数来实现求解,在main()函数中,负责输入输出及调用求组合数的函数。

 

【项目5-歌手大奖赛计分系列】

  (1)在歌手大奖赛中,有10个评委为参赛的选手打分,分数为0~10分(运行时由人控制)。选手最后得分为:去掉一个最高分和一个最低分后其余8个分数的平均值。请编写一个程序实现(可以先不考虑用自定义函数实现)。

  (2)将计算选手成绩的功能(包括输入成绩、计算和显示结果)利用一个函数void calScore(int n)实现。为增大函数的适用面,有评委人数由函数的参数n决定(这样,在main函数调用时,需要将评委人数作为实参)。

  (3)进一步完善(2)的程序。输入时,难免有录入错误发生,如果输入的成绩不在0-10之间,要求用户立即重新输入(在函数calScore中修改);一次运行程序只计算一位选手成绩太麻烦,要求输出当前选手的最后得分后,提示“按任意键计算下一位选手的成绩,退出请选择N:”如果输入的不是Nn,可以为下一位选手计算成绩(在main函数中进行控制即可)。

  参考运行图:





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迂者-贺利坚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值