12个C语言必背实例分享

 更新时间:2022年11月03日 10:15:55   作者:程序小圆圆  
这篇文章主要和大家介绍12个C语言中必背的实例,文中的示例代码讲解详细,对我们了解和掌握C语言有一定的帮助,感兴趣的小伙伴快跟随小编一起了解一下

1.十进制数转换二进制数

实例代码

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

运行结果:

程序分析

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

2.判断某一年是否为闰年

实例代码

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

运行结果:

程序分析

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

3.使用*打印平行四边形

实例代码

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

运行结果:

程序分析

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

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

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

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

4.在控制台打印出著名的杨辉三角

实例代码

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

程序分析

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

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

5.实现投票统计功能

实例代码

//实现功能:某次选举,共有3个候选人,
//输入参加选举的人数及每个人选举的内容,输出3个候选人最终的得票数及无效选票数
//
 
#include "stdio.h"
 
int main(){
 
    int NO1 = 0;
    int NO2 = 0;
    int NO3 = 0;
    int b = 0;
    int n, a[50];
 
    printf("请输入参加选举的人数:\n");//最大50
    scanf("%d", &n);
    printf("请给候选人投票,1或2或3\n");
    for (int i = 0; i < n; i++) {
        scanf("%d", &a[i]);
    }
    for (int i = 0; i < n; i++) {
        if (a[i] == 1) {
            NO1++;
        }
        else if (a[i] == 2) {
            NO2++;
        } else if (a[i] == 3) {
            NO3++;
        } else {
            b++;
        }
    }
    printf("投票结果如下:\n");
    printf("一号选手:%d票\n二号选手:%d票\n三号选手:%d票\n无效票数:%d\n", NO1, NO2, NO3, b);
}

运行结果:

程序分析

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

6.交换数组中最大数和最小数的位置

实例代码

//
//实现功能:交换数组中最大数和最小数的位置
//
 
#include "stdio.h"
 
int main(){
    int a[10];
    int max, min;
    int m, n;
 
    printf("请输入10个数字:\n");
    for (int i = 0; i < 10; i++) {
        scanf("%d", &a[i]);
    }
    printf("输入的10个数是:\n");
    for (int i = 0; i < 10; i++) {
        printf("%4d", a[i]);
    }
    printf("\n");
    max = a[0];
    for (int i = 0; i < 10; i++) {
        if (a[i] > max) {
            max = a[i];
            m = i;
        }
    }
 
    min = a[0];
    for (int i = 0; i < 10; i++) {
        if (a[i] < min) {
            min = a[i];
            n = i;
        }
    }
 
    a[m] = min;
    a[n] = max;
 
    printf("交换最大数和最小数的位置后:\n");
    for (int i = 0; i < 10; i++) {
        printf("%4d", a[i]);
    }
}  //
// Created by 冲哥 on 2020/9/13.
//实现功能:交换数组中最大数和最小数的位置
//
 
#include "stdio.h"
 
int main(){
    int a[10];//定义数组
    int max, min;//定义最大值和最小值
    int m, n;//定义最大值和最小值的位置
 
    printf("请输入10个数字:\n");
    for (int i = 0; i < 10; i++) {
        scanf("%d", &a[i]);
    }
    printf("输入的10个数是:\n");
    for (int i = 0; i < 10; i++) {
        printf("%4d", a[i]);
    }
    printf("\n");
    max = a[0];
    for (int i = 0; i < 10; i++) {
        if (a[i] > max) {
            max = a[i];//找最大值
            m = i;
        }
    }
 
    min = a[0];
    for (int i = 0; i < 10; i++) {
        if (a[i] < min) {
            min = a[i];//找最小值
            n = i;
        }
    }
 
    a[m] = min;
    a[n] = max;
 
    printf("交换最大数和最小数的位置后:\n");
    for (int i = 0; i < 10; i++) {
        printf("%4d", a[i]);
    }
}//
// Created by 冲哥 on 2020/9/13.
//实现功能:交换数组中最大数和最小数的位置
//
 
#include "stdio.h"
 
int main(){
    int a[10];//定义数组
    int max, min;//定义最大值和最小值
    int m, n;//定义最大值和最小值的位置
 
    printf("请输入10个数字:\n");
    for (int i = 0; i < 10; i++) {
        scanf("%d", &a[i]);
    }
    printf("输入的10个数是:\n");
    for (int i = 0; i < 10; i++) {
        printf("%4d", a[i]);
    }
    printf("\n");
    max = a[0];
    for (int i = 0; i < 10; i++) {
        if (a[i] > max) {
            max = a[i];//找最大值
            m = i;
        }
    }
 
    min = a[0];
    for (int i = 0; i < 10; i++) {
        if (a[i] < min) {
            min = a[i];//找最小值
            n = i;
        }
    }
 
    a[m] = min;
    a[n] = max;
 
    printf("交换最大数和最小数的位置后:\n");
    for (int i = 0; i < 10; i++) {
        printf("%4d", a[i]);
    }
}

运行结果:

程序分析

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

7.反转字符串

实例代码

//
//实现功能:输入一个字符串,然后将该字符串反向输出
//
 
#include "stdio.h"
#include "string.h"
 
#define N 50
 
void convert_str(char str[N]);
 
void convert_str(char str[N]){
    int j;
    char temp;
    for (int i = 0; i < strlen(str)/2; i++) {
        j = strlen(str) - 1;
        temp = str[i];
        str[i] = str[j - i];
        str[j - i] = temp;
    }
    printf("反向输出:%s", str);
}
 
int main(){
    char str[N];
    printf("请输入字符串:\n");
    gets_s(str, N);
    printf("输入的字符串为:%s\n", str);
    convert_str(str);
}

运行结果:

程序分析

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

8.使用goto语句从循环中跳出

实例代码

//
// Created by 冲哥 on 2020/9/15.
//实现功能:使用goto语句从循环中跳出
//
 
#include "stdio.h"
 
#define EXIT 0
 
void show_Menu(){
    printf("菜单选项:\t");
    printf("1:显示\t");
    printf("2:添加\t");
    printf("3:查询\t");
    printf("4:删除\t");
    printf("0:退出\n");
}
 
int main(){
    int num;
    show_Menu();
    for (int i = 1; i < 10; i++) {
        printf("第%d此循环\n", i);
        do {
            printf("请输入菜单选项:\n");
            scanf("%d", &num);
            if (num == EXIT){
                goto exit;
            }
            printf("****************菜单功能部分****************\n");
        } while (num < 4);
    }
exit:
    printf("程序退出!\n");
    return 0;
}

运行结果:

程序分析

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

9.计算字符串中单词的个数

实例代码

//
//实现功能:计算字符串中单词的个数
//
 
#include "stdio.h"
 
#define LEN 100
 
int main(){
    char str[LEN];
    int index;
    char blank;
    int words = 1;
 
    printf("请输入字符串:\n");
    gets_s(str, LEN);
 
    if (str[0] == '\0') {
        printf("输入的字符串为空\n");
    } else if (str[0] == ' ') {
        printf("输入的字符串的第一个字符是空格\n");
    } else {
        for (int i = 0; str[i] != '\0'; ++i) {
            blank = str[i];
            if (blank == ' ') {
                words++;
            }
        }
        printf("输入的字符串中有%d个单词\n", words);
    }
}

运行结果:

程序分析

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

10.控制台打印系统的日期和时间

实例代码

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

运行结果:

程序分析

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

11.将3个数由大到小的顺序输出

实例代码

//
//实现功能:输入三个整数,然后按由大到小的顺序输出
//
 
#include "stdio.h"
 
void swap(int *pa, int *pb){
    int temp;
    temp = *pa;
    *pa = *pb;
    *pb = temp;
}
 
void compare(int *pa, int *pb, int *pc){
    if (*pa < *pb) {
        swap(pa, pb);
    }
    if (*pa < *pc) {
        swap(pa, pc);
    }
    if (*pb, *pc) {
        swap(pb, pc);
    }
}
 
int main(){
    int a, b, c, *pa, *pb, *pc;
    printf("请输入三个数:\n");
    scanf("%d%d%d", &a, &b, &c);
    pa = &a;
    pb = &b;
    pc = &c;
    compare(pa, pb, pc);
    printf("%d\t%d\t%d\n", a, b, c);
    return 0;
}

运行结果

程序分析

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

12.模拟用户名登陆

实例代码

//
//实现功能:模拟用户名登陆
 
#include "stdio.h"
#include "string.h"
 
int main(){
    char user_name[20] = {"zhangsan"};
    char password[7]={"123456"};
 
    char name[20], pwd[20];
    int i = 0;
    while (i < 3) {
        printf("请输入用户名:\n");
        gets_s(name, 20);
        printf("请输入密码:\n");
        gets_s(pwd, 7);
        if (strcmp(user_name, name) != 0) {
            printf("您好,您输入的用户名有误!请重新输入:\n");
        } else {
            if (strcmp(password, pwd) != 0) {
                printf("您好,您输入的密码有误!请重新输入:\n");
            } else {
                printf("欢迎使用!\n");
                break;
            }
        }
        i++;
    }
    if (i == 3) {
        printf("输入错误已达3次,账号被锁定!\n");
    }
}

运行结果

正常系

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

异常系

D:\Users\source\C\Test0823\cmake-build-debug\Test0823.exe
请输入用户名:
zhang
请输入密码:
123456
您好,您输入的用户名有误!请重新输入:
请输入用户名:
zhangsan
请输入密码:
1234
您好,您输入的密码有误!请重新输入:
请输入用户名:
zhangs
请输入密码:
123
您好,您输入的用户名有误!请重新输入:
输入错误已达3次,账号被锁定!
 
Process finished with exit code 0

程序分析

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

str1 = str2 返回值为0

str1 > str2 返回值大于0

str1 < str2 返回值小于0

到此这篇关于12个C语言必背实例分享的文章就介绍到这了,更多相关C语言实例内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C/C++ProtoBuf使用小结

    C/C++ProtoBuf使用小结

    ProtoBuf全称:protocol buffers,直译过来是:“协议缓冲区”,是一种与语言无关、与平台无关的可扩展机制,用于序列化结构化数据,这篇文章主要介绍了C/C++ProtoBuf使用,需要的朋友可以参考下
    2024-01-01
  • C++语法详解之封装、构造函数、析构函数

    C++语法详解之封装、构造函数、析构函数

    这篇文章主要介绍了C++语法详解之封装、构造函数、析构函数的相关知识,通过实例代码给大家详细介绍,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • C++ 实现静态链表的简单实例

    C++ 实现静态链表的简单实例

    这篇文章主要介绍了C++ 实现静态链表的简单实例的相关资料,需要的朋友可以参考下
    2017-06-06
  • c语言快速排序算法示例代码分享

    c语言快速排序算法示例代码分享

    快速排序使用分治法(Divide and conquer)策略来把一个串行(list)分为两个子串行(sub-lists)
    2014-02-02
  • 利用C语言如何实现一些简单图形的打印

    利用C语言如何实现一些简单图形的打印

    这篇文章主要给大家介绍了关于利用C语言如何实现一些简单图形的打印的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • C语言详解实现猜数字游戏步骤

    C语言详解实现猜数字游戏步骤

    猜数字是兴起于英国的益智类小游戏,起源于20世纪中期,一般由两个人或多人玩,也可以由一个人和电脑玩。游戏规则为一方出数字,一方猜,今天我们来实现这个游戏案例
    2022-07-07
  • 教你分辨C++堆与栈的区别

    教你分辨C++堆与栈的区别

    堆与栈的区别有:1、栈由系统自动分配,而堆是人为申请开辟;2、栈获得的空间较小,而堆获得的空间较大;3、栈由系统自动分配,速度较快,而堆一般速度比较慢;4、栈是连续的空间,而堆是不连续的空间
    2021-06-06
  • QT树的具体项目实现

    QT树的具体项目实现

    本文主要介绍了QT树的具体项目实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • 内部排序之堆排序的实现详解

    内部排序之堆排序的实现详解

    本篇文章是对堆排序的实现进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言中储存类别与内存管理的深入理解

    C语言中储存类别与内存管理的深入理解

    这篇文章主要给大家介绍了关于C语言中储存类别与内存管理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03

最新评论