【练习1】输出 "Hello, World!"

0. 题目:

输出 "Hello, World!"

1. 分析:

使用 printf() 输出 "Hello, World!"。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. printf("Hello, World!"); // printf() 中字符串的前后需要使用双引号
  5. return 0;
  6. }

3. 输入输出:

Hello, World!

4. 扩展知识:

printf() 是头文件 stdio.h 中定义的函数,调用格式为:

printf("<格式化字符串>", <参量表>);


【练习2】输出整数

0. 题目:

输出整数

1. 分析:

使用 printf() 与 %d 格式化输出整数。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int intNum; // 声明 int 变量
  5. printf("输入一个整数: "); // printf() 输出字符串
  6. scanf("%d", &intNum); // scanf() 格式化输入,"%d"表示整数格式
  7. printf("输入的整数是: %d", intNum); // printf() 显示格式化输入
  8. return 0;
  9. }

3. 输入输出:

输入一个整数: 255

输入的整数是: 255

4. 扩展知识:

scanf() 是头文件 stdio.h 中定义的函数,从标准输入 stdin 读取格式化输入。


【练习3】输出单个字符

0. 题目:

输出单个字符

1. 分析:

使用 printf() 与 %c 格式化输出一个字符。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. char oneChar; // 声明 char 变量
  5. oneChar = 'C'; // 向变量赋值
  6. printf("oneChar 的值为 %c", oneChar); // printf() 格式化输出
  7. return 0;
  8. }

3. 输入输出:

oneChar 的值为 C

4. 扩展知识:

基本数据类型

int:整型

short:短整型

long:长整型

float:浮点型(单精度)

double:浮点型(双精度)

char:字符型

void:无类型


【练习4】输出浮点数

0. 题目:

输出浮点数

1. 分析:

使用 printf() 与 %f 输出浮点数。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. float fVar1,fVar2; // 声明浮点数变量
  5. fVar1 = 12.00123; // 向变量赋值
  6. printf("fVar1 的值为 %f\n", fVar1); // printf() 格式化输出
  7. fVar2 = 123.001234; // 向变量赋值
  8. printf("fVar2 的值为 %f\n", fVar2); // printf() 格式化输出
  9. return 0;
  10. }

3. 输入输出:

fVar1 的值为 12.00123

fVar2 的值为 123.001236

【注意!】 fVar1 的值与赋值完全相同,但 fVar2 的的值与赋值不完全相同。这是因为 float 为单精度浮点数,内存中占 4个字节,有效数位是 7位。如果有效数字位数超过 7位,超出的部分会自动四舍五入。


【练习5】输出双精度数

0. 题目:

输出双精度数

1. 分析:

使用 printf() 与 %e 输出双精度数。

2. 程序:

  1. #include <stdio.h>
  2. {
  3. double dVar1,dVar2; // 声明浮点数变量
  4. dVar1 = 12.00123; // 向变量赋值
  5. printf("dVar1 的值为 %Lf\n", dVar1); // 格式化输出:长实数
  6. printf("dVar1 的值为 %Le\n", dVar1); // 格式化输出:科学计数法
  7. dVar2 = 123.001234; // 向变量赋值
  8. printf("dVar2 的值为 %Lf\n", dVar2); // 格式化输出:长实数
  9. printf("dVar2 的值为 %Le\n", dVar2); // 格式化输出:科学计数法
  10. return 0;
  11. }

3. 输入输出:

dVar1 的值为 12.001230

dVar1 的值为 1.200123e+001

dVar2 的值为 123.001234

dVar2 的值为 1.230012e+002

【注意!】 double 为双精度浮点数,内存中占 8个字节,有效数位是 16位。dVar2 按科学计数法格式(Le)输出时虽然与赋值不完全相同,这只是格式化输出时的有效数字位数限制所致,但在实际存储和计算时都是与赋值完全相同的,因此在按长实数格式(Lf)输出时与赋值完全相同


【练习6】两个数字相加

0. 题目:

题目两个数字相加

1. 分析:

分析使用 scanf() 来接收输入, printf() 与 %d 格式化输出整数。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int firstNum, secondNum, sumNum;
  5. printf("输入两个整数(以空格分隔): ");
  6. // scanf() 格式化输入,接收用户输入的两个整数
  7. scanf("%d %d", &firstNum, &secondNum);
  8. // 两个整数相加
  9. sumNum = firstNum + secondNum;
  10. // 输出结果
  11. printf("%d + %d = %d", firstNum, secondNum, sumNum);
  12. return 0;
  13. }

3. 输入输出:

输入两个数(以空格分割): -1 99

-1 + 99 = 98

【注意!】 由于scanf()函数中定义的输入格式为"%d %d"(两个%d之间有一个空格),在输入时就必须严格按照定义的格式,在输入的两个整数之间加一个空格,否则可能出错。类似地,如果定义输入格式为"%d,%d",就必须在在输入的两个整数之间加一个逗号。


【练习7】两个浮点数相乘

0. 题目:

两个浮点数相乘

1. 分析:

输入两个浮点数,计算乘积。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. double firstNum, secondNum, productNum;
  5. printf("输入两个浮点数(以空格分隔): ");
  6. scanf("%lf %lf", &firstNum, &secondNum);
  7. productNum = firstNum * secondNum; // 两个浮点数相乘
  8. printf("%.2lf * %.2lf = %.2lf\n", firstNum,secondNum,productNum);
  9. printf("%lf * %lf = %lf\n", firstNum,secondNum,productNum);
  10. return 0;
  11. }

3. 输入输出:

输入两个浮点数(以空格分割): 1.2345 66

1.23 * 66.00 = 81.48

1.234500 * 66.000000 = 81.477000

【注意!】(1)变量 secondNum 定义为浮点数,虽然输入为整数也是按浮点数存储的。(2)%.2lf 表示输出格式为保留2位有效数字,但并不影响存储的数据的精度。


【练习8】字符转 ASCII 码

0. 题目:

字符转 ASCII 码

1. 分析:

ASCII 定义了 128 个字符:

(1)0-31、127(删除键)是控制字符

(2)空白字符:空格(32)、 制表符、 垂直制表符、 换行、 回车。

(3)可显示字符:a-z、A-Z、0-9、~、!、@、、%、^、&、#、$、*、(、)、-、+、{、}、[、]、'、"、<、>、,、?、/、|、\、_、:、;、.,还有顿号、。

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. char oneChar; // 声明 char 变量
  5. printf("输入一个字符: ");
  6. scanf("%c", &oneChar); // 读取用户输入
  7. printf("%c 的 ASCII 为 %d", oneChar, oneChar); // %c 字符格式
  8. return 0;
  9. }

3. 输入输出:

输入一个字符: A

A 的 ASCII 为 65


【练习9】两数相除

0. 题目:

两数相除

1. 分析:

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

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int dividend, divisor, quotient, remainder;
  5. printf("输入被除数、除数(以空格分隔): ");
  6. // scanf() 格式化输入,接收用户输入的两个整数
  7. scanf("%d %d", &dividend, &divisor); // 输入被除数、除数
  8. quotient = dividend / divisor; // 除法,分子除分母的整数部分
  9. remainder = dividend % divisor; // % 为模运算,整除后的余数
  10. printf("商 = %d, 余数 = %d", quotient,remainder);
  11. return 0;
  12. }

3. 输入输出:

输入被除数、除数(以空格分隔): 50 10 输出:商 = 5, 余数 = 0

输入被除数、除数(以空格分隔): 51 10 输出:商 = 5, 余数 = 1

输入被除数、除数(以空格分隔): 55 10 输出:商 = 5, 余数 = 5

输入被除数、除数(以空格分隔): 58 10 输出:商 = 5, 余数 = 8

【注意!】除法“/”得出的商是被除数与除数相除的整数部分,不做四舍五入处理。


【练习10】数值比较

0. 题目:

数值比较

1. 分析:

定义了两个整数变量,使用 if 来比较两个数值

2. 程序:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int firstNum, secondNum;
  5. printf("输入两个整数(以空格分隔): ");
  6. scanf("%d %d", &firstNum, &secondNum);
  7. if(firstNum > secondNum)
  8. printf("%d 大于 %d", firstNum,secondNum);
  9. else if(firstNum < secondNum)
  10. printf("%d 小于 %d", firstNum,secondNum);
  11. else
  12. printf("%d 等于 %d", firstNum,secondNum);
  13. return 0;
  14. }

3. 输入输出:

输入两个整数(以空格分割): -1 99

-1 小于 99


版权说明:本文的题目和例程 源于 菜鸟教程,作者重新编写了程序、注释和算例,并增加了难点分析。

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

  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题(41-50)

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

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

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

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

    [练习11]计算 int, float, double 和 char 字节大小 0. 题目: 计算 int, float, double 和 char 字节大小 1. 分析: 使用 sizeof 操作 ...

  6. Python 3.X 练习集100题 01

    有以下几个数字:1.2.3.4.5,能组成多少个互不相同且无重复数字的三位数?都是多少? 方法1: import itertools from functools import reduce lyst ...

  7. python经典例题100题01

    [程序1] 题目:有1.2.3.4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? ans = [i*100+j*10+k for i in range(1, 5) for j in ra ...

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

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

  9. python面试的100题(10)

    18.反转一个整数,例如-123 --> -321 class Solution(object): def reverse(self,x): if -10<x<10: return ...

随机推荐

  1. Java 在Excel中添加水印(单一水印、平铺水印)

    在Excel中没有直接添加水印的功能,但依旧可以通过一定方式来实现类似水印效果.本文通过Java程序代码介绍具体实现方法.可添加单一水印效果,即水印是以单个文本字样来呈现:也可添加多个平铺水印效果,即 ...

  2. Java后端部署以及与Android通信注意事项

    1 概述 本文列举了一些Android+后端Java通信/部署时的问题以及注意事项,覆盖的问题包括但不限于安全组.数据库.路径等,如果各位读者的Android端不能正常访问Java后端,希望这里的解决 ...

  3. editorconfig、eslint、prettier三者的区别、介绍及使用

    每次搭建新项目都少不了这些工具,但时间一久就忘记了,下次搭新项目时又要四处查官方文档,因此特此记录,主要内容是对这三个工具的理解,以及具体使用方式 editorconfig 理解 先看官网的定义: E ...

  4. Win10双系统安装Gentoo-(附Networkmanagr/Gnome安装)

    安装Gentoo 本文主要参考的是官方Wiki,还有一些网友的经验,在后面的具体安装步骤里会分享对应网友的一些解决办法和相关文章 官方Wiki:https://wiki.gentoo.org/wiki ...

  5. 1.8.7- HTML值label标签

    1.label直接进行包裹input就可以了.

  6. DexHunter的原理分析和使用说明(二)

    本文博客地址:http://blog.csdn.net/qq1084283172/article/details/53715325 前面的博文<Android通用脱壳工具DexHunter的原理 ...

  7. hdu2604 矩阵快速幂

    题意:      给你n个人,排成一个长度是n的队伍,人只有两类f,m,问可以有多少种排法使度列中不出现fff,fmf这样的子串.思路:      一开始暴力,结果超时了,其实这个题目要是能找到类似于 ...

  8. POJ2688状态压缩(可以+DFS剪枝)

    题意:       给你一个n*m的格子,然后给你一个起点,让你遍历所有的垃圾,就是终点不唯一,问你最小路径是多少? 思路:       水题,方法比较多,最省事的就是直接就一个BFS状态压缩暴搜就行 ...

  9. Linux-鸟菜-6-文件与目录的 默认权限、隐藏权、特殊权限

    Linux-鸟菜-6-文件与目录的 默认权限.隐藏权.特殊权限 除了基本r,w,x权限外,在Linux还可以设定其他系统隐藏属性,可以用chattr来设定,和lsattr来查看,但注意一点,CentO ...

  10. 前端基础问题:CSS vertical-align 属性

    CSS vertical-align 属性与基线的那些事~ 定义和用法: vertical-align 属性设置元素的垂直对齐方式. vertical-align只对内联元素(inline.inlin ...