C语言及算法设计课程实验四:选择结构程序设计(上)

简介: C语言及算法设计课程实验四:选择结构程序设计(上)

dce14448918b47698e930ed4e7056b15.jpg


一、实验目的

1aa7f9e3d5c946a68715c04ab7a397ad.jpg


(1) 了解C语言表示逻辑量的方法(以0代表“假”,以非0代表“真”)。

(2) 学会正确使用逻辑运算符和逻辑表达式。

(3) 熟练掌握if语句的使用(包括if语句的嵌套)。

(4) 熟练掌握多分支选择语句——switch语句。

(5) 结合程序掌握一些简单的算法。

(6) 进一步学习调试程序的方法。


二、实验内容



5533ad8dd2f74105bb247d9170017017.jpg


2.1、根据x的分段函数求对于的y值


本实验要求事先编好解决下面问题的程序,然后上机输入程序并调试运行程序。

(1) 有一函数:


5b4fc0e8c67945f6b71525e018c29af1.png


写程序,输入x的值,输出 y相应的值。用scanf函数输入x的值,求y值。

运行程序,输入x的值(分别为x<1,1≤x<10,x≥10这3种情况),检査输出的y值 是否正确。


2.2、求小于1000正数的平方根


(2)从键盘输入一个小于1000的正数,要求输出它的平方根(如平方根不是整数,则输 出其整数部分)。要求在输入数据后先对其进行检査是否小于1000的正数。若不是,则要 求重新输入。


2.3、百分制等级输出


(3) 给出一个百分制成绩,要求输出成绩等级A,B,C,D,E。90分以上为A,81〜89分为B,70-79分为C,60-69分为D,60分以下为E。

①事先编好程序,要求分别用if语句和switch语句来实现。运行程序,并检查结果是否正确。


②再运行一次程序,输入分数为负值(如-70):这显然是输入时出错,不应给出等级, 修改程序,使之能正确处理任何数据,当输入数据大于100和小于0时,通知用户“输入数据错”,程序结束。


2.4、四个整数的顺序输出


(4) 输入4个整数,要求按由小到大顺序输出。

在得到正确结果后,修改程序使之按由大到小顺序输出。


三、实验步骤



1cdd77d077c84d198bef06c7f57cb2b0.jpg



3.1、选择结构程序设计实验题目1:根据x的分段函数求对于的y值


本实验要求事先编好解决下面问题的程序,然后上机输入程序并调试运行程序。

(1) 有一函数:

5b4fc0e8c67945f6b71525e018c29af1.png


  • 写程序,输入x的值,输出 y相应的值。用scanf函数输入x的值,求y值。
  • 运行程序,输入x的值(分别为x<1,1≤x<10,x≥10这3种情况),检査输出的y值 是否正确。


3.1.1、定义变量


程序定义变量的代码如下所示

  /// <summary>
  /// 定义变量
  /// </summary>
  /// <returns></returns>
  int x, y;


3.1.2、输入函数自变量的值


程序输入函数自变量的值的代码如下所示

  /// <summary>
  /// 输入函数自变量的值
  /// </summary>
  /// <returns></returns>
  printf("输入x:");
  scanf("%d", &x);

3.1.3、计算函数因变量的值


程序计算函数因变量的值的代码如下所示

  if (x < 1) // x<1
  {
    // 计算函数因变量的值
    y = x;
  }
  else if (x < 10) // 1=<x<10
  {
    // 计算函数因变量的值
    y = 2 * x - 1;
  }
  else // x> = 10
  {
    // 计算函数因变量的值
    y = 3 * x - 10;
  }


3.1.4、输出函数因变量的值

程序输出函数因变量的值的代码如下所示

  if (x < 1) // x<1
  {
    // 计算函数因变量的值
    y = x;
    // 输出函数因变量的值
    printf("x=%3d,  y=x=%d\n", x, y);
  }
  else if (x < 10) // 1=<x<10
  {
    // 计算函数因变量的值
    y = 2 * x - 1;
    // 输出函数因变量的值
    printf("x=%d,  y=2*x-1=%d\n", x, y);
  }
  else // x> = 10
  {
    // 计算函数因变量的值
    y = 3 * x - 10;
    // 输出函数因变量的值
    printf("x=%d,  y=3*x-10=%d\n", x, y);
  }

3.1.5、根据x的分段函数求对于的y值 的运行结果

程序根据x的分段函数求对于的y值 的运行结果如下所示

  1. x的值小于1


8a19552aea424c5089d2297dccd33a5a.jpg


2.x的值大于等于1 小于10


706e7d94a4054b838cf276ccf8640b43.jpg


3.x的值大于等于10


c8d01703040a457bbcf9b21f58b4625c.jpg


3.2、选择结构程序设计实验题目2:求小于1000正数的平方根


(2)从键盘输入一个小于1000的正数,要求输出它的平方根(如平方根不是整数,则输出其整数部分)。


  • 要求在输入数据后先对其进行检査是否小于1000的正数。
  • 若不是,则要 求重新输入。


3.2.1、定义变量与宏

程序定义变量与宏的代码如下所示


  // 定义宏
  #define M 1000
  /// <summary>
  /// 定义变量
  /// </summary>
  /// <returns></returns>
  int digit, k;

3.2.2、输入一个小于1000的整数


程序输入一个小于1000的整数的代码如下所示

  /// <summary>
  /// 输入一个小于1000的整数
  /// </summary>
  /// <returns></returns>
  printf("请输入一个小于%d的整数digit: ", M);
  scanf("%d", &digit);


3.2.3、输入大于1000, 则从新输入一个整数


程序输入大于1000, 则从新输入一个整数的代码如下所示

  /// <summary>
  /// 输入大于1000, 则从新输入一个整数
  /// </summary>
  /// <returns></returns>
  while (digit > M)
  {
    printf("输人的数据不符合要求,请重新输入一个小于%d的整数digit:  ", M);
    scanf("%d", &digit);
  }


相关文章
|
3月前
|
存储 算法 C语言
"揭秘C语言中的王者之树——红黑树:一场数据结构与算法的华丽舞蹈,让你的程序效率飙升,直击性能巅峰!"
【8月更文挑战第20天】红黑树是自平衡二叉查找树,通过旋转和重着色保持平衡,确保高效执行插入、删除和查找操作,时间复杂度为O(log n)。本文介绍红黑树的基本属性、存储结构及其C语言实现。红黑树遵循五项基本规则以保持平衡状态。在C语言中,节点包含数据、颜色、父节点和子节点指针。文章提供了一个示例代码框架,用于创建节点、插入节点并执行必要的修复操作以维护红黑树的特性。
95 1
|
5天前
|
存储 算法 数据管理
C语言算法复杂度
【10月更文挑战第20天】
C语言算法复杂度
|
4天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
10 3
|
16天前
|
存储 缓存 算法
如何通过优化算法和代码结构来提升易语言程序的执行效率?
如何通过优化算法和代码结构来提升易语言程序的执行效率?
|
22天前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
77 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
22天前
|
存储 算法 C语言
【C语言】二分查找算法
【C语言】二分查找算法
|
29天前
|
算法
计科一二班算法数据结构实验9答案
计科一二班算法数据结构实验9答案
13 0
|
1月前
|
搜索推荐 C语言 C++
【C语言】指针篇-精通库中的快速排序算法:巧妙掌握技巧(4/5)
【C语言】指针篇-精通库中的快速排序算法:巧妙掌握技巧(4/5)
|
3月前
|
算法 Java 测试技术
算法分析(蛮力法与减治算法应用实验报告)
这篇文章是关于算法分析的实验报告,介绍了如何使用蛮力法解决背包问题,并通过伪代码和Java代码实现,同时分析了其时间效率;还介绍了基于减治法思想实现的二叉查找树的插入与查找,同样提供了伪代码、Java源代码实现和时间效率分析,最后展示了测试结果截图。
算法分析(蛮力法与减治算法应用实验报告)
|
3月前
|
机器学习/深度学习 算法 Java
算法设计(动态规划应用实验报告)实现基于贪婪技术思想的Prim算法、Dijkstra算法
这篇文章介绍了基于贪婪技术思想的Prim算法和Dijkstra算法,包括它们的伪代码描述、Java源代码实现、时间效率分析,并展示了算法的测试用例结果,使读者对贪婪技术及其应用有了更深入的理解。
算法设计(动态规划应用实验报告)实现基于贪婪技术思想的Prim算法、Dijkstra算法