当前位置:   article > 正文

12个C语言必背实例_c语言案例

c语言案例

C语言实例第01期,十进制数转换二进制数

实例代码

  1. //
  2. #include "stdio.h"
  3. int main(){
  4.     int m, n, k;//定义变量
  5.     int a[16= { 0 };
  6.     printf("请输入一个0~32767之间的数字:\n");
  7.     scanf("%d"&n);
  8.     printf("十进制数%d转换为二进制数是:\n", n);
  9.     for (int i = 0; i < 15++i) {//for循环从0-14,最高位为符号位,本例始终为0
  10.         m = n % 2;//2的余数
  11.         k = n / 2;//取被2整除的结果
  12.         n = k;
  13.         a[i] = m;//将余数存入数组a数组中
  14.     }
  15.     for (int i = 15; i >=0 ; i--) {//for循环将数组中的16个元素从后往前输出
  16.         printf("%d", a[i]);
  17.         if (i % 4 == 0) {//每输出4个元素,输出一个空格
  18.             printf(" ");
  19.         }
  20.     }
  21. }

运行结果:

程序分析

本实例比较简单,而且注释也比较详细,这里需要注意的是第二个for循环是从后往前输出15~0,因为第一个for循环对2取余的结果存入数组时是从a[0]开始存储的。

C语言实例第02期,判断某一年是否为闰年

实例代码

  1. //
  2. // Created by 冲哥 on 2020/9/7.
  3. //
  4. #include "stdio.h"
  5. int main(){
  6.     int year;//定义整形变量year
  7.     printf("请输入要查询的年份:\n");
  8.     scanf("%d"&year);//从键盘输入要查询的年份
  9.     if ((year % 4 == 0 && year % 100 !=0) || year % 400 == 0) {//判断是否为闰年的条件
  10.         printf("%d年这一年是闰年\n", year);
  11.     } else {
  12.         printf("%d年这一年不是闰年\n", year);
  13.     }
  14. }

运行结果:

 

程序分析

今天分享的也是一个入门级实例,从键盘输入一个表示年份的整数,判断该年份是否为闰年。该实例的要点就是判断闰年的算法:(year % 4 == 0 && year % 100 !=0) || year % 400 == 0

C语言实例第03期,使用*打印平行四边形

实例代码

  1. //
  2. #include "stdio.h"
  3. int main(){
  4.     char arr[5= {'*','*','*','*','*'};
  5.     for (int i = 0; i < 5; i++) {//输出5
  6.         for (int j = 1; j <= i; j++) {
  7.             printf(" ");//输出空格的数量随着行数的变化而变化
  8.         }
  9.         for (int k = 0; k < 5; k++) {
  10.             printf("%c", arr[k]);//输出数组中的元素
  11.         }
  12.         printf("\n");//输出一行后换行
  13.     }
  14. }

运行结果:

程序分析

本实例的要点就是理解三个for循环

  • 第一个for循环控制整个图形的行数,本实例中的图形共5行,所以i的范围为0~4。

  • 第二个for循环用来控制空格的数量。

  • 第三个for循环用将数组a中的元素逐个输出。

C语言实例第04期,在控制台打印出著名的杨辉三角

实例代码

  1. //
  2. #include "stdio.h"
  3. int main(){
  4.     int a[8][8]={0};//初始化数组(本实例打印8行)
  5.     for (int i = 0; i < 8; i++) {//for循环定义每行的第一个数和对角线上的数,数值为1
  6.         a[i][i] = 1;
  7.         a[i][0= 1;
  8.     }
  9.     for (int k = 2; k < 8; k++) {
  10.         for (int j = 1; j < k; j++) {//用两个for循环实现除对角线和每行第一个元素外其他元素的赋值
  11.             a[k][j] = a[k-1][j-1+ a[k-1][j];
  12.         }
  13.     }
  14.     for (int i = 0; i < 8; i++) {
  15.         for (int j = 0; j <= i; j++) {//两个for循环将数组a中的所有元素输出
  16.             printf("%d\t", a[i][j]);
  17.         }
  18.         printf("\n");
  19.     }
  20. }

运行结果:

程序分析

首先要分析杨辉三角的特点,找出规律:

处理每行第一个数和对角线上的数都是1意外,其它的数就是前一行相邻的两数之和。找到这个规律,就可以很轻松的用for循环实现了。

C语言实例第05期,实现投票统计功能

实例代码

  1. //实现功能:某次选举,共有3个候选人,
  2. //输入参加选举的人数及每个人选举的内容,输出3个候选人最终的得票数及无效选票数
  3. //
  4. #include "stdio.h"
  5. int main(){
  6.     int NO1 = 0;
  7.     int NO2 = 0;
  8.     int NO3 = 0;
  9.     int b = 0;
  10.     int n, a[50];
  11.     printf("请输入参加选举的人数:\n");//最大50
  12.     scanf("%d"&n);
  13.     printf("请给候选人投票,1或2或3\n");
  14.     for (int i = 0; i < n; i++) {
  15.         scanf("%d"&a[i]);
  16.     }
  17.     for (int i = 0; i < n; i++) {
  18.         if (a[i] == 1) {
  19.             NO1++;
  20.         }
  21.         else if (a[i] == 2) {
  22.             NO2++;
  23.         } else if (a[i] == 3) {
  24.             NO3++;
  25.         } else {
  26.             b++;
  27.         }
  28.     }
  29.     printf("投票结果如下:\n");
  30.     printf("一号选手:%d票\n二号选手:%d票\n三号选手:%d票\n无效票数:%d\n"NO1NO2NO3, b);
  31. }

运行结果:

程序分析

输入参加选举的人数,再输入每个人的选举内容并将其存入数组中。对存入数组中的元素进行判断,统计出各个候选人的票数和无效的票数。

C语言实例第06期:交换数组中最大数和最小数的位置

实例代码

  1. //
  2. //实现功能:交换数组中最大数和最小数的位置
  3. //
  4. #include "stdio.h"
  5. int main(){
  6.     int a[10];
  7.     int max, min;
  8.     int m, n;
  9.     printf("请输入10个数字:\n");
  10.     for (int i = 0; i < 10; i++) {
  11.         scanf("%d"&a[i]);
  12.     }
  13.     printf("输入的10个数是:\n");
  14.     for (int i = 0; i < 10; i++) {
  15.         printf("%4d", a[i]);
  16.     }
  17.     printf("\n");
  18.     max = a[0];
  19.     for (int i = 0; i < 10; i++) {
  20.         if (a[i] > max) {
  21.             max = a[i];
  22.             m = i;
  23.         }
  24.     }
  25.     min = a[0];
  26.     for (int i = 0; i < 10; i++) {
  27.         if (a[i] < min) {
  28.             min = a[i];
  29.             n = i;
  30.         }
  31.     }
  32.     a[m] = min;
  33.     a[n] = max;
  34.     printf("交换最大数和最小数的位置后:\n");
  35.     for (int i = 0; i < 10; i++) {
  36.         printf("%4d", a[i]);
  37.     }
  38. }  //
  39. // Created by 冲哥 on 2020/9/13.
  40. //实现功能:交换数组中最大数和最小数的位置
  41. //
  42. #include "stdio.h"
  43. int main(){
  44.     int a[10];//定义数组
  45.     int max, min;//定义最大值和最小值
  46.     int m, n;//定义最大值和最小值的位置
  47.     printf("请输入10个数字:\n");
  48.     for (int i = 0; i < 10; i++) {
  49.         scanf("%d"&a[i]);
  50.     }
  51.     printf("输入的10个数是:\n");
  52.     for (int i = 0; i < 10; i++) {
  53.         printf("%4d", a[i]);
  54.     }
  55.     printf("\n");
  56.     max = a[0];
  57.     for (int i = 0; i < 10; i++) {
  58.         if (a[i] > max) {
  59.             max = a[i];//找最大值
  60.             m = i;
  61.         }
  62.     }
  63.     min = a[0];
  64.     for (int i = 0; i < 10; i++) {
  65.         if (a[i] < min) {
  66.             min = a[i];//找最小值
  67.             n = i;
  68.         }
  69.     }
  70.     a[m] = min;
  71.     a[n] = max;
  72.     printf("交换最大数和最小数的位置后:\n");
  73.     for (int i = 0; i < 10; i++) {
  74.         printf("%4d", a[i]);
  75.     }
  76. }//
  77. // Created by 冲哥 on 2020/9/13.
  78. //实现功能:交换数组中最大数和最小数的位置
  79. //
  80. #include "stdio.h"
  81. int main(){
  82.     int a[10];//定义数组
  83.     int max, min;//定义最大值和最小值
  84.     int m, n;//定义最大值和最小值的位置
  85.     printf("请输入10个数字:\n");
  86.     for (int i = 0; i < 10; i++) {
  87.         scanf("%d"&a[i]);
  88.     }
  89.     printf("输入的10个数是:\n");
  90.     for (int i = 0; i < 10; i++) {
  91.         printf("%4d", a[i]);
  92.     }
  93.     printf("\n");
  94.     max = a[0];
  95.     for (int i = 0; i < 10; i++) {
  96.         if (a[i] > max) {
  97.             max = a[i];//找最大值
  98.             m = i;
  99.         }
  100.     }
  101.     min = a[0];
  102.     for (int i = 0; i < 10; i++) {
  103.         if (a[i] < min) {
  104.             min = a[i];//找最小值
  105.             n = i;
  106.         }
  107.     }
  108.     a[m] = min;
  109.     a[n] = max;
  110.     printf("交换最大数和最小数的位置后:\n");
  111.     for (int i = 0; i < 10; i++) {
  112.         printf("%4d", a[i]);
  113.     }
  114. }

运行结果:

程序分析

首先找到数组中的最大值和最小值,记录它们的位置,然后交换位置,最后将交换后的数组输出。

C语言实例第07期:反转字符串

实例代码

  1. //
  2. //实现功能:输入一个字符串,然后将该字符串反向输出
  3. //
  4. #include "stdio.h"
  5. #include "string.h"
  6. #define N 50
  7. void convert_str(char str[N]);
  8. void convert_str(char str[N]){
  9.     int j;
  10.     char temp;
  11.     for (int i = 0; i < strlen(str)/2; i++) {
  12.         j = strlen(str) - 1;
  13.         temp = str[i];
  14.         str[i] = str[j - i];
  15.         str[j - i] = temp;
  16.     }
  17.     printf("反向输出:%s", str);
  18. }
  19. int main(){
  20.     char str[N];
  21.     printf("请输入字符串:\n");
  22.     gets_s(str, N);
  23.     printf("输入的字符串为:%s\n", str);
  24.     convert_str(str);
  25. }

运行结果:

程序分析

注意:实例中有这样一个语句j = strlen(str) - 1;这里j为什么是j = strlen(str) - 1;而不是strlen(str)呢?原因如下:如果数组s中含有10个元素,那么它的长度为10,而s的数组下标从0开始那么下标的最大值为9,j这里是代表数组下标,所以开始时的最大值应是strlen(str)-1也就是9。

C语言实例第08期:使用goto语句从循环中跳出

实例代码

  1. //
  2. // Created by 冲哥 on 2020/9/15.
  3. //实现功能:使用goto语句从循环中跳出
  4. //
  5. #include "stdio.h"
  6. #define EXIT 0
  7. void show_Menu(){
  8.     printf("菜单选项:\t");
  9.     printf("1:显示\t");
  10.     printf("2:添加\t");
  11.     printf("3:查询\t");
  12.     printf("4:删除\t");
  13.     printf("0:退出\n");
  14. }
  15. int main(){
  16.     int num;
  17.     show_Menu();
  18.     for (int i = 1; i < 10; i++) {
  19.         printf("第%d此循环\n", i);
  20.         do {
  21.             printf("请输入菜单选项:\n");
  22.             scanf("%d"&num);
  23.             if (num == EXIT){
  24.                 goto exit;
  25.             }
  26.             printf("****************菜单功能部分****************\n");
  27.         } while (num < 4);
  28.     }
  29. exit:
  30.     printf("程序退出!\n");
  31.     return 0;
  32. }

运行结果:

程序分析

goto语句后面会有一个标识符goto exit;当程序满足goto条件时,程序就会直接跳转到标识符位置。

C语言实例第09期:计算字符串中单词的个数

实例代码

  1. //
  2. //实现功能:计算字符串中单词的个数
  3. //
  4. #include "stdio.h"
  5. #define LEN 100
  6. int main(){
  7.     char str[LEN];
  8.     int index;
  9.     char blank;
  10.     int words = 1;
  11.     printf("请输入字符串:\n");
  12.     gets_s(str, LEN);
  13.     if (str[0== '\0') {
  14.         printf("输入的字符串为空\n");
  15.     } else if (str[0== ' ') {
  16.         printf("输入的字符串的第一个字符是空格\n");
  17.     } else {
  18.         for (int i = 0; str[i] != '\0'++i) {
  19.             blank = str[i];
  20.             if (blank == ' ') {
  21.                 words++;
  22.             }
  23.         }
  24.         printf("输入的字符串中有%d个单词\n", words);
  25.     }
  26. }

运行结果:

程序分析

用for循环遍历字符数组,然后判断是不是结尾\0,如果不是,就判断是不是空格,是空格的话,单词数加1.

C语言实例第10期:控制台打印系统的日期和时间

实例代码

  1. //
  2. //实现功能:控制台打印系统的日期和时间
  3. //
  4. #include "stdio.h"
  5. #include "time.h"
  6. int main(){
  7.     struct tm *sysTime;//定义结构体,用于存放日期和时间
  8.     time_t sysDay;
  9.     time(&sysDay);//获取系统日期
  10.     sysTime = localtime(&sysDay);//转换为系统日期
  11.     printf("系统日期:%d-%d-%d\n"1900 + sysTime->tm_year, sysTime->tm_mon + 1, sysTime->tm_mday);
  12.     printf("系统时间:%d:%d:%d\n", sysTime->tm_hour, sysTime->tm_min, sysTime->tm_sec);
  13.     return 0;
  14. }

运行结果:

程序分析

本实例主要掌握系统日期和时间的获取方法。

C语言实例第11期:将3个数由大到小的顺序输出

实例代码

  1. //
  2. //实现功能:输入三个整数,然后按由大到小的顺序输出
  3. //
  4. #include "stdio.h"
  5. void swap(int *pa, int *pb){
  6.     int temp;
  7.     temp = *pa;
  8.     *pa = *pb;
  9.     *pb = temp;
  10. }
  11. void compare(int *pa, int *pb, int *pc){
  12.     if (*pa < *pb) {
  13.         swap(pa, pb);
  14.     }
  15.     if (*pa < *pc) {
  16.         swap(pa, pc);
  17.     }
  18.     if (*pb, *pc) {
  19.         swap(pb, pc);
  20.     }
  21. }
  22. int main(){
  23.     int a, b, c, *pa, *pb, *pc;
  24.     printf("请输入三个数:\n");
  25.     scanf("%d%d%d"&a, &b, &c);
  26.     pa = &a;
  27.     pb = &b;
  28.     pc = &c;
  29.     compare(pa, pb, pc);
  30.     printf("%d\t%d\t%d\n", a, b, c);
  31.     return 0;
  32. }

运行结果

程序分析

还记不记得之前讲过的传址和传值,这里就用到了传址。

C语言实例第12期:模拟用户名登陆

实例代码

  1. //
  2. //实现功能:模拟用户名登陆
  3. #include "stdio.h"
  4. #include "string.h"
  5. int main(){
  6.     char user_name[20= {"zhangsan"};
  7.     char password[7]={"123456"};
  8.     char name[20], pwd[20];
  9.     int i = 0;
  10.     while (i < 3) {
  11.         printf("请输入用户名:\n");
  12.         gets_s(name, 20);
  13.         printf("请输入密码:\n");
  14.         gets_s(pwd, 7);
  15.         if (strcmp(user_name, name) != 0) {
  16.             printf("您好,您输入的用户名有误!请重新输入:\n");
  17.         } else {
  18.             if (strcmp(password, pwd) != 0) {
  19.                 printf("您好,您输入的密码有误!请重新输入:\n");
  20.             } else {
  21.                 printf("欢迎使用!\n");
  22.                 break;
  23.             }
  24.         }
  25.         i++;
  26.     }
  27.     if (i == 3) {
  28.         printf("输入错误已达3次,账号被锁定!\n");
  29.     }
  30. }

运行结果

正常系

  1. D:\Users\source\C\Test0823\cmake-build-debug\Test0823.exe
  2. 请输入用户名:
  3. zhangsan
  4. 请输入密码:
  5. 123456
  6. 欢迎使用!
  7. Process finished with exit code 0

异常系

  1. D:\Users\source\C\Test0823\cmake-build-debug\Test0823.exe
  2. 请输入用户名:
  3. zhang
  4. 请输入密码:
  5. 123456
  6. 您好,您输入的用户名有误!请重新输入:
  7. 请输入用户名:
  8. zhangsan
  9. 请输入密码:
  10. 1234
  11. 您好,您输入的密码有误!请重新输入:
  12. 请输入用户名:
  13. zhangs
  14. 请输入密码:
  15. 123
  16. 您好,您输入的用户名有误!请重新输入:
  17. 输入错误已达3次,账号被锁定!
  18. Process finished with exit code 0

程序分析

本实例中使用到了字符串的比较函数strcmp(str1, str2);,这个函数的功能是按照ASCII码顺序比较两个字符串,并由返回值返回比较结果。

  • str1 = str2 返回值为0

  • str1 > str2 返回值大于0

  • str1 < str2 返回值小于0

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/527905
推荐阅读
相关标签
  

闽ICP备14008679号