《C语言程序设计》第三章练习与习题答案

[练3-1]
不需要;因为已经涵盖了所有可能的条件。
[练3-2]
#include<stdio.h>
int main(void)
{
int y;
double x;
printf("Enter x:");
scanf("%lf",&x);
if(x<0)
y=-1;
else if(x==0)
y=0;
else
y=1;
printf("y=sign(%f)=%d\n",x,y);
return 0;
}
[练3-3]
#include<stdio.h>
int main(void)
{
char ch;
int i,digit,letter,SE,other;
printf("Enter 15 characters:");
digit=letter=SE=other=0;
for(i=1;i<=15;i )
{
ch=getchar();
if(ch>='0'&&ch<='9')
digit ;
else if((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z'))
letter ;
else if(ch==' '||ch=='\n')
SE ;
else
other ;
}
printf("digit=%d,letter=%d,SE=%d,other=%d\n",digit,letter,SE,other);
return 0;
}
[练3-4]
会改变;输出“price=0.0”;不使用break时,不但会执行符合语句段,还执行其后的所有语句段。
[练3-5]
#include<stdio.h>
int main(void)
{
double value1,value2;
char operato;
printf("Type in an expression:");
scanf("%lf%c%lf",&value1,&operato,&value2);
switch(operato)
{
case' ':
printf("=%.2f\n",value1 value2);
break;
case'-':
printf("=%.2f\n",value1-value2);
break;
case'*':
printf("=%.2f\n",value1*value2);
break;
case'/':
if(value2==0)
printf("You are wrong\n");
else
printf("=%.2f\n",value1/value2);
break;
default:
printf("Unknown operator\n");
break;
}
return 0;
}
[练3-6]
#include<stdio.h>
int main(void)
{
char level;
printf("Enter level(A~E):");
level=getchar();
switch(level)
{
case 'A':
printf("90~100\n");
break;
case'B':
printf("80~89\n");
break;
case'C':
printf("70~79\n");
break;
case'D':
printf("60~69\n");
break;
case'E':
printf("0~59\n");
break;
default:
printf("Wrong level\n");
break;
}
return 0;
}
[练3-7]
#include<stdio.h>
int main(void)
{
int i,choice;
double price;
printf("[1] apples\n");
printf("[2] pears\n");
printf("[3] oranges\n");
printf("[4] grapes\n");
printf("[0] Exit\n");
for(i=1;i<=5;i )
{
printf("Enter choice:");
scanf("%d",&choice);
if(choice==0)
{
printf("Byebye!\n");
break;
}
switch(choice)
{
case 1:
price=3.00;
break;
case 2:
price=2.50;
break;
case 3:
price=4.10;
break;
case 4:
price=10.20;
break;
default:
price=0.00;
}
printf("price=%.2f\n",price);
if((i==5)&&(choice!=0))
printf("You have used five times.Please try again.\n");
}
return 0;
}
【练3-8】
#include<stdio.h>
int main(void)
{
int year;
printf("Enter year:");
scanf("%d",&year);
if((year%4==0&&year0!=0)||(year@0==0))
{
printf("It is leap year.\n");
}
else
{
printf("It isn't leap year.\n");
}
return 0;
}
【练3-9】
#include<stdio.h>
int main(void)
{
int n,i,count;
double total,grade;
printf("Enter n:");
scanf("%d",&n);
total=0;
count=0;
for(i=1;i<=n;i )
{
printf("Enter grade #%d:",i);
scanf("%lf",&grade);
total=total grade;
if(grade>=60)
{
count ;
}
}
printf("The avaerage = %.2f\n",total/n);
printf("The number of qualifies = %d\n",count);
return 0;
}
【练3-10】
#include<stdio.h>
int main(void)
{
double x,y;
printf("Enter x:");
scanf("%lf",&x);
if(x<0)
{
y=0;
}
if(x>=0)
{
if(x<=15)
{
y=4*x/3;
}
else
{
y=2.5*x-10.5;
}
}
printf("f(%.2f) = %.2f\n",x,y);
return 0;
}
【练3-11】
改写前两条语句的执行条件是:x小于1;x大于等于1且小于2。改写后两条语句的执行条件是:x小于1;x大于等于2。
【习题3-1】
#include<stdio.h>
#include<math.h>
int main(void)
{
int a,b,c;
double area,s,perimeter,part;
printf("Enter a:");
scanf("%d",&a);
printf("Enter b:");
scanf("%d",&b);
printf("Enter c:");
scanf("%d",&c);
if((a b>c)&&(b c>a)&&(c a>b))
{
s=(a b c)/2;
part=s*(s-a)*(s-b)*(s-c);
area=sqrt(part);
perimeter=a b c;
printf("Area = %.2f\n",area);
printf("Perimeter = %.2f\n",perimeter);
}
else
{
printf("These sides do not correspond to a valid triangle.\n");
}
return 0;
}
【习题3-2】
#include<stdio.h>
int main(void)
{
int salary,rate;
double tax;
printf("Enter salary:");
scanf("%d",&salary);
if(salary<=850)
{
rate=0;
}
else if(salary<=1350)
{
rate=5;
}
else if(salary<=2850)
{
rate=10;
}
else if(salary<=5850)
{
rate=15;
}
else
{
rate=20;
}
tax=rate*(salary-850)/100;
printf("Tax = %.2f\n",tax);
return 0;
}
【习题3-3】
#include<stdio.h>
int main(void)
{
int km,min;
double part,money;
printf("Enter km:");
scanf("%d",&km);
printf("Enter min:");
scanf("%d",&min);
if(km<=3)
{
money=10;
}
else
{
money=10 (km-3)*3;
}
if(min>0)
{
part=min/5;
money=money part*3;
}
printf("Money = %.0f\n",money);
return 0;
}
【习题3-4】
#include<stdio.h>
int main(void)
{
int a,b,c,d,e,n,i;
double grade,sum,average;
printf("Enter n:");
scanf("%d",&n);
a=b=c=d=e=sum=0;
for(i=1;i<=n;i )
{
printf("Enter grade#%d:",i);
scanf("%lf",&grade);
sum=sum grade;
if(grade<60)
{
e ;
}
else if(grade<70)
{
d ;
}
else if(grade<80)
{
c ;
}
else if(grade<90)
{
b ;
}
else
{
a ;
}
}
average=sum/n;
printf("Average = %.2f\n",average);
printf("A = %d\nB = %d\nC = %d\nD = %d\nE = %d\n",a,b,c,d,e);
return 0;
}
【习题3-5】
#include<stdio.h>
int main(void)
{
int i;
for(i=2000;i<=3000;i )
{
if(((i%4==0)&&(i0!=0))||(i@0==0))
{
printf("%d\n",i);
}
}
return 0;
}

转载于:https://www.cnblogs.com/yinyuyou-ycy/archive/2012/04/26/2472843.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/475186.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 调用js 解析yml_nodejs库yaml读取yml或yaml配置文件

最近在使用TypeScript编写后台接口时&#xff0c;需要读取yaml配置文件&#xff0c;使用到了yaml这个nodejs库&#xff0c;其npm官网地址为&#xff1a;https://www.npmjs.com/package/yaml&#xff0c;github源代码地址为&#xff1a;github.com/eemeli/yaml比如有如下的confi…

java执行程序默认多线程吗_Java多线程 执行程序(1)

本文由作者收集整理所得&#xff0c;作者不保证内容的正确行&#xff0c;转载请标明出处。作者&#xff1a;关新全Java多线程执行程序(1)1.1Thread类static Thread.currentThread返回当前正在执行的线程对象的引用。join 等待线程终止。yield 暂停当前正在执行的线程对象&#…

LeetCode 531. 孤独像素 I

文章目录1. 题目2. 解题1. 题目 给定一幅黑白像素组成的图像, 计算黑色孤独像素的数量。 图像由一个由‘B’和‘W’组成二维字符数组表示, ‘B’和‘W’分别代表黑色像素和白色像素。 黑色孤独像素指的是在同一行和同一列不存在其他黑色像素的黑色像素。 示例: 输入: [[W,…

SSL证书配置指南

http://verisign.itrus.com.cn/html/fuwuyuzhichi/fuwuqizhengshuanzhuangpeizhizhinan/转载于:https://www.cnblogs.com/freeman-rain/archive/2012/04/27/2472856.html

LeetCode 533. 孤独像素 II

文章目录1. 题目2. 解题1. 题目 给定一幅由黑色像素和白色像素组成的图像&#xff0c; 与一个正整数N, 找到位于某行 R 和某列 C 中且符合下列规则的黑色像素的数量: 行R 和列C都恰好包括N个黑色像素。列C中所有黑色像素所在的行必须和行R完全相同。 图像由一个由‘B’和‘W…

简单的数据查询

简单查询的构成&#xff1a;由SELECT 子名 FROM 表 WHERE条件 ORDER BY 排序组成. 练习&#xff1a; 1.查询所有Inter的CPUSELECT * FROM sheet1$ WHERE c_name LIKE intel% 2.查询价格在100-200之间的金士顿内存SELECT * FROM sheet1$ WHERE c_money BETWEEN 100 AND 200 GROU…

java数组显示最大值,java 如何用方法在数组中找到最大值并显示他的名称?

public static void sub(int racetime[], String name[]) {int maxIndex 0; // 记录racetime最大值的下标for (int i 1; i if (racetime[i] > racetime[maxIndex]) {maxIndex i;}}System.out.println("Racetime最大的是" name[maxIndex]);}追问如何将 main和s…

Windows 8桌面的尴尬

刚出炉的Windows8可谓荣宠极致&#xff0c;此时却被指出存在问题&#xff0c;面临失宠的尴尬。到底是什么问题呢&#xff1f; Windows 8中新的用户界面&#xff0c;已被完全证明是两级分化日益严重。  混合操作系统是一个新的GUI概念&#xff0c;友好地触摸界面接口&#xff…

LeetCode 1101. 彼此熟识的最早时间(排序+并查集)

文章目录1. 题目2. 解题1. 题目 在一个社交圈子当中&#xff0c;有 N 个人。每个人都有一个从 0 到 N-1 唯一的 id 编号。 我们有一份日志列表 logs&#xff0c;其中每条记录都包含一个非负整数的时间戳&#xff0c;以及分属两个人的不同 id&#xff0c;logs[i] [timestamp,…

php管道的概念,让你的php命令行程序处理管道数据

linux下有一个强大的命令|(管道提示符).它的作用是将前一个命令的结果交给后一条命令并作为后一条命令的输入.而linux下的大多数命令也都支持这种方式.可是当笔者写完一个php的命令行小程序以后,对于怎样获得前一个命令的结果却陷入了僵局.难道php不支持这样的操作?于是又开始…

【转载】世界各地对BI的应用状况

欧美企业对商务智能的应用 商务智能活动在美国和欧洲比在世界上任何其他地区都要发达&#xff0c;商务智能已经由“旁门左道”转变为“主门正道”。欧美的企业已经认识到商务智能的重要意义&#xff0c;因而对它寄予很高的期望&#xff0c;希望能够通过商务智能充分利用企业以往…

php gearman 扩展,Ubuntu 12.04 安装 gearman 以及php扩展安装脚本

#!/usr/bash#create by lhb#date 2014-05-07#desc install gearman and php extension for Ubuntu 12.04.4 LTS PHP 5.5apt-get update#安装依赖库apt-get install libboost-all-dev gperf libevent1-dev libcloog-ppl0mkdir -pv /home/lhb/software && cd /home/lhb/s…

LeetCode 379. 电话目录管理系统(哈希set)

文章目录1. 题目2. 解题1. 题目 设计一个电话目录管理系统&#xff0c;让它支持以下功能&#xff1a; get: 分配给用户一个未被使用的电话号码&#xff0c;获取失败请返回 -1check: 检查指定的电话号码是否被使用release: 释放掉一个电话号码&#xff0c;使其能够重新被分配 …

数据异构

当下数据系统纷杂&#xff0c;每个公司都可能有多种多样的系统&#xff0c;然而每个系统都可能有部分业务数据可供外部使用。然后&#xff0c;貌似总能听到这个系统与那个系统进行交互的时候&#xff0c;开发人员总是在激烈的讨论如何互相开放API接口。但是这样的API接口真的够…

php sem acquire,PHP | 关于php中sem_get failed for key no space left on device问题的解决方案...

有时我们在处理并发操作时会使用信号量做进程同步,如下一个php应用的例子$sem_id sem_get($id,1,0666,true);sem_acquire($sem_id);...sem_release($sem_id);我们release了资源,但是系统没有真正的释放资源 通过 [rootlocalhost ~]# ipcs -s------ Semaphore Arrays -------- …

LeetCode 250. 统计同值子树(递归)

文章目录1. 题目2. 解题1. 题目 给定一个二叉树&#xff0c;统计该二叉树数值相同的子树个数。 同值子树是指该子树的所有节点都拥有相同的数值。 示例&#xff1a; 输入: root [5,1,5,5,5,null,5]5/ \1 5/ \ \5 5 5 输出: 4来源&#xff1a;力扣&#xff08;LeetC…

开启MySQL远程访问权限 允许远程连接

1、登陆mysql数据库 mysql -u root -p 查看user表 mysql> use mysql;Database changedmysql> select host,user,password from user;---------------------------------------------------------------| host | user | password …

php 函数报错,PHP报错函数error_reporting()怎么用?

PHP中&#xff0c;报错函数error_reporting()用于规定应该报告何种PHP错误&#xff0c;语法“error_reporting(level)”&#xff1b;使用该函数可以设置在脚本运行时的错误级别&#xff0c;如果没有设置可选参数level&#xff0c;则仅返回当前的错误报告级别。推荐&#xff1a;…

LeetCode 426. 将二叉搜索树转化为排序的双向链表(BST中序循环遍历)

文章目录1. 题目2. 解题1. 题目 将一个 二叉搜索树 就地转化为一个 已排序的双向循环链表 。 对于双向循环列表&#xff0c;你可以将左右孩子指针作为双向循环链表的前驱和后继指针&#xff0c;第一个节点的前驱是最后一个节点&#xff0c;最后一个节点的后继是第一个节点。 …

ASP.NET中Request.IsAuthenticated和Request.User.Identity.IsAuthenticated的区别

Reflector 查看 System.Web.dll 中 HttpRequest.cs 的代码&#xff1a; public bool IsAuthenticated {get{return (((this._context.User ! null) && (this._context.User.Identity ! null)) && this._context.User.Identity.IsAuthenticated);} }所以说这两者…