【练习11】计算 int, float, double 和 char 字节大小

0. 题目:

计算 int, float, double 和 char 字节大小

1. 分析:

使用 sizeof 操作符计算int, float, double 和 char四种变量字节大小。

sizeof 是单目操作符,以字节形式给出了其操作数的存储大小。

2. 程序:

#include <stdio.h>
int main()
{
int integerType;
float floatType;
double doubleType;
char charType; // sizeof 操作符用于计算变量的字节大小
printf("Size of int: %ld bytes\n",sizeof(integerType));
printf("Size of float: %ld bytes\n",sizeof(floatType));
printf("Size of double: %ld bytes\n",sizeof(doubleType));
printf("Size of char: %ld byte\n",sizeof(charType)); return 0;
}

3. 输入输出:

Size of int: 4 bytes

Size of float: 4 bytes

Size of double: 8 bytes

Size of char: 1 byte


【练习12】交换两个数的值

0. 题目:

交换两个数的值

1. 分析:

本例程使用中间变量。

2. 程序:

#include <stdio.h>
int main()
{
float firstNum, secondNum, tempVar; printf("输入两个浮点数(以空格分隔): ");
scanf("%f %f", &firstNum, &secondNum); tempVar = firstNum;
firstNum = secondNum;
secondNum = tempVar; printf("\n交换后 firstNum = %.2f", firstNum);
printf("\n交换后 secondNum = %.2f", secondNum); return 0;
}

3. 输入输出:

输入两个浮点数(以空格分隔): 1 2

交换后 firstNum = 2.00

交换后 secondNum = 1.00


【练习13】判断奇数/偶数

0. 题目:

判断奇数/偶数

1. 分析:

判断用户输入的整数是奇数还是偶数。

2. 程序:

#include <stdio.h>
int main()
{
int iNum; printf("输入一个整数: ");
scanf("%d", &iNum); // 判断这个数除以 2 的余数
if(iNum % 2 == 0)
printf("%d 是偶数。", iNum);
else
printf("%d 是奇数。", iNum); return 0;
}

3. 输入输出:

输入一个整数: 99

99 是奇数。


【练习14】区间内的奇偶判断

0. 题目:

判断循环区间内的奇数/偶数

1. 分析:

循环输出区间范围内的奇数/偶数可以通过除于 2 的余数来判断。

2. 程序:

#include <stdio.h>
int main()
{
int i;
for(i=1;i<=10;i++)
{
if(i%2 == 0)
printf(" %d\n", i);
}
return 0;
}

3. 输入输出:

2

4

6

8

10


【练习15】判断元音/辅音

0. 题目:

判断元音/辅音

1. 分析:

判断输入的字母是元音还是辅音。英语有26个字母,只有 a、e、i、o、u 是元音。

2. 程序:

#include <stdio.h>
int main()
{
char cInput;
int isLowercaseVowel, isUppercaseVowel; printf("输入一个字母: ");
scanf("%c",&cInput); isLowercaseVowel = ((cInput=='a') || (cInput=='e') || (cInput=='i') || (cInput=='o') || (cInput=='u')); // 小写字母元音
isUppercaseVowel = ((cInput=='A') || (cInput=='E') || (cInput=='I') || (cInput=='O') || (cInput=='U')); // 大写字母元音 if (isLowercaseVowel || isUppercaseVowel)
printf("%c 是元音。", cInput);
else
printf("%c 是辅音。", cInput);
return 0;
}

3. 输入输出:

输入一个字母: S

S 是辅音

【注意!】 关系运算符 '==" 优先于 逻辑运算符 "||",因此 (cInput=='a') 中的小括号 ()也可以省略。


【练习16】判断三个数中的最大数

0. 题目:

判断三个数中的最大数

1. 分析:

分析使用 scanf() 来接收输入,if 分支语句进行条件判断。

2. 程序:

#include <stdio.h>
int main()
{
float fNum1, fNum2, fNum3; printf("请输入 3 个数(以逗号分隔): ");
scanf("%f,%f,%f", &fNum1, &fNum2, &fNum3); if(fNum1>=fNum2 && fNum1>=fNum3 )
printf("最大数是 %.2f。", fNum1); if(fNum2>=fNum1 && fNum2>=fNum3 )
printf("最大数是 %.2f。", fNum2); if(fNum3>=fNum1 && fNum3>=fNum1 )
printf("最大数是 %.2f。", fNum3); return 0;
}

3. 输入输出:

请输入三个数(以逗号分隔): 0,1,2

最大数是 2.00

【注意!】 1、本程序采用的多次条件判断并不是最好的方法,但思路容易理解,程序可读性也较好。2、如果将题目理解为找到最大数的数值,这个程序是正确的;但如果将题目理解为找到第几个数是最大数,则不仅输出结果不符合要求,而且整体算法也存在Bug。


【练习17】一元二次方程

0. 题目:

一元二次方程

1. 分析:

求一元二次方程:ax2+bx+c=0 的根。

输入三个实数a,b,c的值,且a不等于0。

2. 程序:

#include <stdio.h>
#include <math.h>
int main()
{
float fParaA,fParaB,fParaC,fRoofX1,fRoofX2,fDelta; printf("\n一元二次方程:ax2+bx+c=0:");
printf("\n输入系数a,b,c(以逗号分隔):");
scanf("%f %f %f",&fParaA,&fParaB,&fParaC); if(fParaA!=0)
{
fDelta = fParaB*fParaB - 4*fParaA*fParaC;
if(fDelta>0)
{
fRoofX1=(-fParaB+sqrt(fDelta))/(2*fParaA);
fRoofX2=(-fParaB-sqrt(fDelta))/(2*fParaA);
printf("x1 = %0.2f, x2 = %0.2f\n",fRoofX1,fRoofX2);
}
else if(fDelta==0)
{
fRoofX1=(-fParaB+sqrt(fDelta))/(2*fParaA);
printf("x1 = x2 = %0.2f\n",fRoofX1);
}
else
{
printf("方程无实数解!\n");
}
} return 0;
}

3. 输入输出:

一元二次方程:ax2+bx+c=0:

输入系数a,b,c(以逗号分隔):1,4,-5

x1 = 1.00, x2 = -5.00


【练习18】判断闰年

0. 题目:

判断闰年

1. 分析:

能被4整除的年份是闰年,但被100整除的年份不是闰年;但被400整除的年份还是闰年。

2. 程序:

#include <stdio.h>
int main()
{
int iYear; printf("输入年份: ");
scanf("%d",&iYear); //被4整除的年份是闰年,但被100整除的年份不是闰年,但被400整除的年份还是闰年
if((iYear%4 == 0 && iYear%100 != 0) || iYear%400 == 0)
printf("%d 是闰年", iYear);
else
printf("%d 不是闰年", iYear); return 0;
}

3. 输入输出:

输入年份: 2021

2021不是闰年


【练习19】判断正数/负数

0. 题目:

判断正数/负数/零

1. 分析:

两数相除,如果有余数,输出余数

2. 程序:

#include <stdio.h>
int main()
{
float fNum; printf("输入一个实数: ");
scanf("%f", &fNum); if(fNum < 0.0)
printf("输入的 %.2f 是负数\n",fNum);
else if(fNum > 0.0)
printf("输入的 %.2f 是正数\n",fNum);
else
printf("输入的 %.2f 是零\n",fNum); return 0;
}

3. 输入输出:

输入一个实数: 0.0

输入的 0.00 是零

【注意!】该程序将输入值与数值 0.0 比较大小是可以的。但如果比较两个实数变量的大小,由于存在有效数字位数问题,一般不能直接比较二者是否相等。


【练习20】判断输入字符是否字母

0. 题目:

判断输入字符是否字母

1. 分析:

大写字母和小写字母都属于字母

2. 程序:

#include <stdio.h>
int main()
{
char cInput;
printf("输入一个字符: ");
scanf("%c",&cInput); if( (cInput>='a' && cInput<='z') || (cInput>='A' && cInput<='Z'))
printf("%c 是字母",cInput);
else
printf("%c 不是字母",cInput); return 0;
}

3. 输入输出:

输入一个字符: S

S 是字母


版权说明:

题目和例程 源于 菜鸟教程,作者重新编写了程序、注释和算例,并增加了难点分析。

C语言编程 菜鸟练习100题(11-20)的更多相关文章

  1. C语言编程 菜鸟练习100题(21-30)

    [练习21]计算自然数的和 0. 题目: 计算自然数的和 1. 分析: 练习使用 for 循环结构.for 循环允许一个执行指定次数的循环控制结构. 2. 程序: #include <stdio ...

  2. C语言编程 菜鸟练习100题(51-60)

    [练习51]矩阵转置 0. 题目: 矩阵的转置 1. 分析: 练习使用 for 循环嵌套,多维数组的表达. 2. 程序: #include <stdio.h> int main() { i ...

  3. C语言编程 菜鸟练习100题(31-40)

    [练习31]判断质数 0. 题目: 判断质数 1. 分析: 质数(prime number),指大于 1的.且除 1 和本身以外没有其他因数的自然数. 2. 程序: #include <stdi ...

  4. C语言编程 菜鸟练习100题(41-50)

    [练习41]字符串翻转 0. 题目: 字符串翻转 1. 分析: 学习递归思想和方法. 2. 程序: 方法一: #include <stdio.h> void reverseSentence ...

  5. C语言编程 菜鸟练习100题(01-10)

    [练习1]输出 "Hello, World!" 0. 题目: 输出 "Hello, World!" 1. 分析: 使用 printf() 输出 "He ...

  6. C语言编程学习打造——做题游戏

    C语言是面向过程的,而C++是面向对象的 C和C++的区别: C是一个结构化语言,它的重点在于算法和数据结构.C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现 ...

  7. python面试的100题(20)

    76.递归函数停止的条件? 递归的终止条件一般定义在递归函数内部,在递归调用前要做一个条件判断,根据判断的结果选择是继续调用自身,还是return:返回终止递归.终止的条件:1.判断递归的次数是否达到 ...

  8. C语言100题集合004-统计各个年龄阶段的人数

    系列文章<C语言经典100例>持续创作中,欢迎大家的关注和支持. 喜欢的同学记得点赞.转发.收藏哦- 后续C语言经典100例将会以pdf和代码的形式发放到公众号 欢迎关注:计算广告生态 即 ...

  9. 数据结构+算法面试100题~~~摘自CSDN

    数据结构+算法面试100题~~~摘自CSDN,作者July 1.把二元查找树转变成排序的双向链表(树) 题目:输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表.要求不能创建任何新的结点,只调 ...

随机推荐

  1. Day14_81_反射机制获取Class属性

    反射机制获取Class属性 获取属性 方法一: Class对象 . getFields();只能用来获取公开的属性,不能获取有私有的或者受保护的属性 获取属性 方法二: Class对象 . getDe ...

  2. 浅入Kubernetes(12):Deployment 的升级、回滚

    目录 更新 上线 会滚 缩放 Deployment 直接设置 Pod 水平自动缩放 比例缩放 暂停 Deployment 上线 本篇内容讨论 Pod 的更新和回滚,内容不多. 更新 打开 https: ...

  3. JavaScript课程——Day07(对象简介、Math对象、时间对象、字符串对象)

    1.对象简介 在javaScipt中,一切皆为对象或者皆可以被用作对象 宿主对象:window,document 内置对象:Number  String  Boolean  Array数组  Obje ...

  4. hdu2899 三分

    题意:      给你个函数,F(x) = 6 * x^7+8*x^6+7*x^3+5*x^2-y*x ,给你一个y,x的范围是0--100 问你最小的 F(x) 思路:       本人推数学公式啥 ...

  5. Linux下性能监控、守护进程与计划任务管理

    目录 一:监视系统进程(ps .top) 二:查看网络连接信息 (netstat) 三:文件进程.端口关联(lsof) 四:计划任务管理(at .crontab) at crontab 一:监视系统进 ...

  6. CVE-2012-0003:Microsoft Windows Media Player winmm.dll MIDI 文件堆溢出漏洞调试分析

    0x01 蜘蛛漏洞攻击包 前言:2012 年 2月,地下黑产中流行着一款国产名为蜘蛛漏洞的攻击包 -- "Zhi-Zhu Exploit Pack",该工具包含 5 个漏洞,都是在 ...

  7. Windows PE第九章 线程局部存储

    线程局部存储(TLS) 这个东西并不陌生了,之前写过了一个关于这个的应用,利用静态TLS姿势实现代码段静态加密免杀或者所谓的加壳思路.地址在这:http://blog.csdn.net/u013761 ...

  8. 数据表格 layui.table

    layui官网-表单 自动渲染 方法渲染 table.render,cols中的field是后台传递的data map.put("data",stuService.selectSt ...

  9. 21.Quick QML-FileDialog、FolderDialog对话框

    1.FileDialog介绍 Qt Quick中的FileDialog文件对话框支持的平台有: 笔者使用的是Qt 5.8以上的版本,模块是import Qt.labs.platform 1.1. 它的 ...

  10. Windows反调试技术(上)

    写在前面 在逆向工程中为了防止破解者调试软件,通常都会在软件中采用一些反调试技术来防破解.下面就是一些在逆向工程中常见的反调试技巧与示例. BeingDebuged 利用调试器加载程序时调试器会通过C ...