《C语言及程序设计》实践参考——函数版星号图

返回:贺老师课程教学链接  项目要求

【项目1-函数版星号图】
这一组的练习意在通过调用函数输出星号图,体会与理解函数的工作过程,并为其后编制自定义函数实现特定功能。
(1)补充完下面的程序,使程序输出星号下面的星号图:

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

[参考解答]

#include <stdio.h>
void printstars(int m) //定义能输出一行m个星号的函数
{
    int j;
    for (j=1; j<=m; ++j)
         printf("*");
}
int main( )
{
  int n=6; //n代表要输出的行数
  int i;
  for(i=1; i<=n; ++i)
    {
        //请在下面写上调用printstars函数的语句,使程序输出右图
        printstars(2*i-1);
        printf("\n");
    }
  return 0;
}

(2)根据main函数中对printchs函数的调用,以及printchs的功能要求,编写printchs函数,使下面的程序能输出星号图:

//调用函数printchs输出星号图
#include <stdio.h>
//在下面写printchs函数的定义,功能是输出一行若干个指定字符

int main( )
{
    int n=6; //n代表要输出的行数
    int i;
    //通过在下面的循环里调用printchs函数,输出右面的图
    for(i=1; i<=n; ++i)
    {
        printchs(n-i,' ');
        printchs(2*i-1,'*') ;
        printf("\n");
    }
    return 0;
}

[参考解答]

//调用函数printchs输出星号图
#include <stdio.h>
//在下面写printchs函数的定义,功能是输出一行若干个指定字符
void printchs(int n, char c)
{
    int j;
    for (j=1; j<=n; ++j)
        printf("%c", c);
}

int main( )
{
    int n=6; //n代表要输出的行数
    int i;
    //通过在下面的循环里调用printchs函数,输出右面的图
    for(i=1; i<=n; ++i)
    {
        printchs(n-i,' ');
        printchs(2*i-1,'*') ;
        printf("\n");
    }
    return 0;
}

(3)在上面的程序中,只改动一处,输出下面的图形

[参考解答]

#include <stdio.h>
//在下面写printchs函数的定义,功能是输出一行若干个指定字符
void printchs(int n, char c)
{
    int j;
    for (j=1; j<=n; ++j)
        printf("%c", c);
}

int main( )
{
    int n=6; //n代表要输出的行数
    int i;
    for(i=1; i<=n; ++i)
    {
        printchs(n-i,' ');
        printchs(2*i-1,'A'+i-1) ;  //输出的符号,与i相关
        printf("\n");
    }
    return 0;
}

(4)利用printchs函数,再实现以前写过的其他星号图,体会定义函数带来了的好处。
[参考解答(无)]

时间: 2024-07-28 13:12:03

《C语言及程序设计》实践参考——函数版星号图的相关文章

2014秋C++第11周项目1参考-函数版星号图

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.   [项目1-函数版星号图]这一组的练习意在通过调用函数输出星号图,体会与理解函数的工作过程,并为其后编制自定义函数实现特定功能.(1)补充完下面的程序,使程序输出星号图: #include <iostream> using namespace std; void printsta

C++实践参考解答 输出星号图

[项目:输出星号图]自选下面的几个图案,编程序输出(自选两个完成,其他的想想思路即可).   (c)"向下的等腰三角"详解 将一个图,看作为6行,完成了第一级的分解,设计的算法框架为: i=1; While(i<=6) //需要输出6行 { 输出第i行; 换行: ++i: } 对于"输出第i行"的任务,可以进行细化: 先输出若干空格(多少个空格?第1行0个,第2行1个,第3行2--第6行5个): 再输出若干个星号(多少星号?第一行11个,第2行9个--第6行1

《C语言及程序设计》实践参考——链表版通信录

返回:贺老师课程教学链接 [项目4-链表版通信录] 利用链表存储数据,写一个通信录程序,能够记录多个联系人的编号.姓名.性别.联系电话.地址,完成数据的录入.添加.删除.修改以及查询功能. [参考解答] 本解答自网络:链接 #include<stdio.h> #include<string.h> #include<stdlib.h> typedef struct //通讯录结点类型 { char num[5]; //编号 char name[9]; //姓名 char

《C++语言基础》实践参考—— 链表类

返回:贺老师课程教学链接  项目要求 [项目 - 链表类]动态链表也是程序设计中的一种非常有用的数据结构.可以说,是否能够理解有关操作的原理,决定了你是否有资格称为"科班"出身.在后续的专业基础课中,相关的内容还会从不同的角度,反复地认识,反复地实践.不过,在现阶段多些体验,也是很有必要的了.(1)阅读下面的程序,回顾一下动态链表,阅读程序过程中,请用笔画一画形成链表的过程中指针值的变化. #include <iostream> using namespace std; s

C++实践参考——OOP版电子词典

[项目-OOP版电子词典] 做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开.(1)编程序,由用户输入英文词,显示词性和中文释义.提示1:如果要用OOP完成这个词典(当然也可以用OO方法实现),可以定义一个Word类表示一个词条,其中的数据成员string english; 表示英文单词,string chinese;表示对应中文意思,string word_class;表示该词的词性:还可以定义一个

《C++语言基础》实践参考——旱冰场造价

返回:贺老师课程教学链接 [项目1 - 旱冰场造价] 有一个圆形的旱冰场地,场地内抹水泥,造价为每平方米M元,围栏用木条围成,每米造价N元,输入旱冰场半径,用程序计算出其造价. 一级提示: 先定义类,确定其数据成员和成员函数.在这里要定义的旱冰场类,实际我们只关心其面积和周长,根据面积计算场地内抹水泥的造价,根据周长计算围栏的造价.有了类的定义,在main函数中定义该类对象,调用成员函数即可以完成求解.二级提示: 实际上,对于旱冰场,我们只关心它就是一个圆.这就是设计中抓住了本质.于是,设计一个

《C++语言基础》实践参考——指向学生类的指针

返回:贺老师课程教学链接 [项目4-指向学生类的指针] 设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set.get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索).在main函数中,要做到: 建立一个对象数组,通过初始化,设置5个学生的数据,要求: 用指针指向数组首元素,输出第1.3.5个学生的信息: 设计一个函数int max(Student *arr);,用指向对象的指针作函数参数,在max函数中

《C++语言基础》实践参考——复数模板类

返回:贺老师课程教学链接 [项目6-复数模板类]    阅读教材例10.1.该例实现了一个复数类,但是美中不足的是,复数类的实部和虚部都固定只能是double型的.可以通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时指定的实际类型.    (1)要求类成员函数在类外定义.    (2)在此基础上,再实现减法.乘法和除法    你可以使用的main()函数如下. int main( ) { Complex<int> c1(3,4),c2(5,-10),c3; //实部和虚

《C++语言基础》实践参考——Josephus(约瑟夫环)问题

返回:贺老师课程教学链接  项目要求 [项目-Josephus(约瑟夫环)问题]n个小孩子围成一圈,从第一个小孩子开始顺时针方向数数字,到第m个小孩子离开,这样反反复复,最终只剩下一个小孩子,求第几个小孩子留下?    提示:约瑟夫环即是一个首尾相连的链表,在建立好这个环以后,从头结点开始,每次间隔m孩子删除一个结点,直至只余下一个结点(删除了n-1个).     参考下面的代码,也可以自行设计类. //链表结点kid,其中number为这个人的编号 struct kid { int numbe