提交要求:
1:邮件名称:学号后三位-题目编号-姓名-期中考试。例如:098-1-沈苗-期中考试
2:不用附件提交,直接写邮件,内容包括编程思路(写一段自己对题目的认识、思路、技术细节等)、源代码、运行结果分析和截图

题目:

1.编程先由计算机“想”一个1到100之间的数请人猜,如果人猜对了,则结束游戏,并在屏幕上输出人猜了多少次才猜对此数,以此来反映猜数者“猜”的水平,否则计算机给出提示,告诉人所猜的数是太大还是太小,最多可以猜10次,如果猜了10次仍未猜中的话,则结束游戏。

编程思路

 1)计算机“想”一个1-100的数,则需要程序在运行的时候随机产生一个1-100之间的自然数,需要使用rand()srand((int)time(0))函数;

 2)猜数者“猜”数:则是用户每次输入的数字与随机产生的数进行比较,使用if..else..进行判断;

 3)  猜数者只有10次机会,则需要使用forwhile循环进行控制次数,本程序选择使用for循环;

 4)另外程序结束和程序判断,需要引入returnbreakcouture等配合;

源代码

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
/*
Author:南非波波
E-mail:qingbo.song@gmail.com
github:@swht
*/ /*
*产生1-n之间的随机数
*注意:请配合srand((int)time(0));
*/
int RandNum(n)
{
return rand()%n + 1;
} int main()
{
srand((int)time(0)); //设置随机数种子
int num = RandNum(100),int_num,i,min=0,max=100;
printf("%d\n",num);
for(i=1;i<=10;i++)
{
printf("===============第%d次=======================\n",i);
printf("请输入一个幸运数字:");
scanf("%d",&int_num);
if (int_num >100 || int_num < 1)
{
printf("你输入的数为%d,不在1-100之间.请重试!\n",int_num);
continue;
}else if(int_num == num){
printf("恭喜你猜中幸运数字,你猜中的幸运数字为:%d,第%d次猜中.\n",int_num,i);
return 0;
}else{
printf("你猜的幸运数字不正确,请重试!\n");
if(int_num > num )
{
max=int_num;
printf("幸运数字范围缩小为%d-%d!\n",min,max);
}else{
min=int_num;
printf("幸运数字范围缩小为%d-%d!\n",min,max);
}
continue;
}
}
printf("你猜数字次数已达10次上限,很抱歉你未能猜中幸运数字,程序退出!\n");
return 0;
}

输出截图

运行结果分析

  该源码程序会在第一行提示当前为第几次输入,提示用户输入的幸运数字缩小的范围,最终用户正确猜中显示用户猜中的数字和当前次数,或者用户输入达到10次,程序遗憾退出!

2.

题目描述:任意给定n个整数,求这n个整数序列的和、最小值、最大值
输入描述:输入一个整数n,代表接下来要输入的整数个数,n<=100,接着输入n个整数
输出描述:输出整数序列的和、最小值和最大值,用空格隔开,占一行
样例输入:
2
1 2
样例输出:
3 1 2

编程思路

  1)用户输入的元素个数不定,需要引入数组的概念进行实现;

  2)求和,既是转变成数组元素遍历,元素值累加,求和,使用for循环进行处理;

  3)求最小数,既是转变成元素遍历,比较各元素大小,求出最小值,使用for循环嵌套if判断进行处理;

  4)求最大数,既是转变成元素遍历,比较各元素大小,求出最大值,使用for循环嵌套if判断进行处理;

源代码:

#include <stdio.h>
#include <stdlib.h>
/*
Author:南非波波
E-mail:qingbo.song@gmail.com
github:@swht
*/
int MaxNum(int num[],int n)
/*
*传入一个整数型数组和对应数组的长度,输出数组元素值最大的下标
*/
{
int i,maxnum=num[0],maxi=0;
for(i=0;i<n;i++)
{
if(num[i]>maxnum)
{
maxnum=num[i];
maxi=i;
}
}
return maxi;
} int MinNum(int num[],int n)
/*
*传入一个整数型数组和对应数组的长度,输出数组元素值最小的下标
*/
{
int i,minnum=num[0],mini=0;
for(i=0;i<n;i++)
{
if(num[i]<minnum)
{
minnum=num[i];
mini=i;
}
}
return mini;
} int SumNum(int num[],int n)
/*
*传入一个整数型数组和对应数组的长度,输出数组所有元素的和
*/
{
int i,sum=0;
for(i=0;i<n;i++)
{
sum +=num[i];
}
return sum;
} int main()
{
int num[100],i,n,imax,imin,sum;
printf("请输入即将要输入整数的个数(1-100):");
scanf("%d",&n);
if(n>100||n<1)
{
printf("你输入的数值不正确,整数个数数值要求在1-100以内!程序退出!");
return 0;
}
printf("请依次输入%d个整数:",n);
for(i=0;i<n;i++)
{
scanf("%d",&num[i]);
}
imax = MaxNum(num,n);
imin = MinNum(num,n);
sum = SumNum(num,n);
printf("%d,%d,%d\n",sum,num[imin],num[imax]);
return 0;
}

截图:

运行结果分析

  在运行结果正确的情况下,对程序进行优化处理,将数组求和、求最小数、求最大数封装成函数,只要传入整数型数组和数组的长度,即可实现函数返回数据元素和、数组最小元素下标和数组最大元素下标;

  增加判断用户输入即将要输入的元素个数进行判断,大于100和小于1的进行异常退出操作;

  如果用户输入的元素不足,则程序不会退出,知道用户输入元素个数满足之前预定的数值,回车才能进行后续处理:

  对于输入元素个数超出之前预定个数,则按照顺序仅取前n个元素值:

3.

外卖费。上了一上午的课,终于到了午饭时间,大家讨论中午吃什么,有人说吃食堂盖饭,有人说吃海底捞,最后宿舍长大人一拍桌子,说:叫外卖!于是开始打电话叫外卖,规则如下:每单少于20元(不含)不予以送餐,每单在20(含)到30(不含)元之间收取8块钱送餐费,每单在30(含)到40(不含)元之间收取5元送餐费,每单在40(含)元以上免费送餐,请你计算这顿午餐的全部费用。
输入格式:输入共2行,第一行包括一个整数n(n>=1&&n<=20),表示这一单一共要了几个菜,第2行有n个浮点数,以空格分开,表示每个菜的价格
输出格式:输出1行,包含一个浮点数,表示全部外卖费,保留小数点后面2位,当不够送餐服务时,输出error
输入样例:
3
10.5 11.5 10.5
输出样例:
37.50

编程思路

  1)分阶段收取配送费,选择使用switch..caseif..else..语句进行判断;

  2)输入菜品个数不定,使用数组的概念,加入for循环遍历数组读取输入的值;

源代码:

#include <stdio.h>
#include <stdlib.h>
/*
Author:南非波波
E-mail:qingbo.song@gmail.com
github:@swht
*/
int main()
{
int n,i;
double sum,totalsum,num[100];
printf("请输入预定餐品数量:");
scanf("%d",&n);
printf("请输入每个餐品的价格:");
for(i=0;i<n;i++)
{
scanf("%lf",&num[i]);
sum += num[i];
}
if(sum >= 20 && sum < 30)
{
totalsum=sum+8;
printf("你此次外卖费(包含运费8元):%.2lf\n",totalsum);
}else if(sum>=30 && sum < 40)
{
totalsum=sum+5;
printf("你此次外卖费(包含运费5元):%.2lf\n",totalsum);
}else if(sum >= 40)
{
totalsum = sum +0;
printf("你此次外卖费(免运费):%.2lf\n",totalsum);
}else{
printf("你此次外卖费小于20元,不予配送,感谢你的支持!");
}
return 0;
}

截图:

运行结果分析

  一定要注意用户输入的个数和输入价格不符的情况,否则引起程序异常。另外需要注意在计算sum值的时候,比较sum值大小是不包含运费在内的。

关于C语言的几个考试编程题目的更多相关文章

  1. 中国MOOC_面向对象程序设计——Java语言_期末考试编程题_1细胞自动机

    期末考试编程题 返回   这是期末考试的编程题 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止时间之前提交答案,系统将取其中的最高分作为最终成 ...

  2. C语言与VT100控制码编程

    C语言与VT100控制码编程 声明: . 如果您打算阅读本文,希望您已经了解过C语言的基本语法,本文不对C语言的基本语法进行说明,因为那些东西几乎唾手可得; . 本文在vim中编辑,请尽量是用vim进 ...

  3. R语言基于S4的面向对象编程

    前言 本文接上一篇文章 R语言基于S3的面向对象编程,本文继续介绍R语言基于S4的面向对象编程. S4对象系统具有明显的结构化特征,更适合面向对象的程序设计.Bioconductor社区,以S4对象系 ...

  4. Go语言面组合式向对象编程基础总结

    转自:http://blog.csdn.net/yue7603835/article/details/44282823 Go语言的面向对象编程简单而干净,通过非侵入式接口模型,否定了C/C++ Jav ...

  5. C语言控制台窗体图形界面编程(总结)

    本系列文章是笔者通过学习<C语言控制台窗体界面编程(修正版)>而写(关于此文档的很多其它信息请看本系列文章第一篇),旨在让大家更加清晰简洁easy地学习C语言控制台窗体界面的编程. 通过本 ...

  6. Python语言基础07-面向对象编程基础

    本文收录在Python从入门到精通系列文章系列 1. 了解面对对象编程 活在当下的程序员应该都听过"面向对象编程"一词,也经常有人问能不能用一句话解释下什么是"面向对象编 ...

  7. 网易云课堂_C++程序设计入门(下)_期末考试_期末考试在线编程题目

    期末考试在线编程题目 返回考试   本次考试题目一共两个,在考试期间可以不限制次数地提交 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止时间 ...

  8. C语言与汇编的嵌入式编程:求100以内素数

    写汇编之前,需要搞清楚C语言代码的写法,这里以最简单的算法举例说明 C代码如下: #include <stdio.h> void main(){ int i,j; ; ;i<=;i+ ...

  9. 为什么C语言是最适合单片机编程的高级语言!

    为什么还在用C语言编程?答案是:C语言是最适合单片机编程的高级语言. 这个问题的意思应该是:现在有很多很好用的高级语言,如java,python等等,为什么这些语言不能用来编写单片机程序呢?那么这个问 ...

随机推荐

  1. GO_00:Mac之Item2的配置安装

    申明:Mac 本上的终端感觉不是那么多好用,以前在 Windows 上操作 Linux 都是通过 XShell 来操作的,界面美观大方.操作使用比较简单.故在 Mac 上也需要有这样一款类似的工具,那 ...

  2. Java基础-Collection子接口之Set接口

    Java基础-Collection子接口之Set接口 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 学习Collection接口时,记得Collection中可以存放重复元素,也可 ...

  3. spring-boot添加自定义拦截器

    spring-boot中的WebMvcConfigurerAdapter类提供了很多自定义操作的方法,先贴出来大家看看 package org.springframework.web.servlet. ...

  4. 自己写的一个小的剪刀——石头——布游戏的GUI程序

    很简单的一个程序,建议各位初学Java的同学可以试试写写这个程序: import javax.swing.JOptionPane; public class Game { public static ...

  5. 微服务深入浅出(7)-- 网关路由Zuul

    Zuul用于构建边界服务,致力于动态路由,过滤,监控,弹性伸缩和安全等方向. 1.Zuul+Ribbon+Eureka结合,可以实现智能路由和负载均衡 2.网关将所有服务的API接口统一聚合统一暴露 ...

  6. tmux终端工具

    本文原始地址:http://www.cnblogs.com/chinas/p/7094172.html,转载请注明出处,谢谢!!! 1.介绍 tmux(终端复用工具):一个很有趣的工具,类似GNU S ...

  7. POJ 1986 Distance Queries (Tarjan算法求最近公共祖先)

    题目链接 Description Farmer John's cows refused to run in his marathon since he chose a path much too lo ...

  8. python之追溯函数调用及错误日志详细打印

    一.函数调用追溯 1.1 原因 在打印日志时,为实现日志分层打印,将打印日志的语句封装到了print_log_info以及print_log_error中.但是如果在上述函数中直接通过logger.* ...

  9. VUE组件相关总结!

    定义使用一个组件 <!doctype html> <html lang="en"> <head> <meta charset=" ...

  10. UNIX环境高级编程 第8章 进程控制

    本章是UNIX系统中进程控制原语,包括进程创建.执行新程序.进程终止,另外还会对进程的属性加以说明,包括进程ID.实际/有效用户ID. 进程标识 每个进程某一时刻在系统中都是独一无二的,它们之间是用一 ...