2021.7.15标准C语言

本文介绍了二进制、八进制、十六进制在计算机中的作用,以及它们之间的转换方法,包括十进制转其他进制和反之。讨论了CPU如何处理二进制数据,以及原码、反码、补码的概念。此外,提到了位运算符的使用,并给出了几个实际操作示例,如设置二进制位和随机数生成。最后,简述了函数在C语言中的应用,包括标准库函数和自定义函数的声明与调用。
摘要由CSDN通过智能技术生成

进制转换:
为什么要会用二进制、八进制、十六进制?
因为现在的CPU只能识别高低两种电流,只能对二进制数据进行计算
因为二进制虽然可以直接被CPU识别计算,但是不方便书写、记录,所以把二进制的数据先转换成八进制的是为了方便记录到文档中‘
随着CPU的不断发展位数不断增加,由早起的8位逐渐发展到了现在的64位,因此八进制不再能满足需求,所以发展出了十六进制,由于历史原因,八进制还不能完全的退出历史舞台

十进制如何转二进制(其他所有进制):
    求余法:
        用2不停的对数据求余,记录余数,然后继续对商求余,直到商为0结束,过程中产生的余数就是该数据的二进制(逆序)
            n  %  2 = 0|1
            商 %  2 = 0|1
            直到商为0
        127 % 2     1
        63  % 2     1
        31  % 2     1
        15  % 2     1
        7   % 2     1
        3   % 2     1
        1   % 2     1
        0           0
        01111111
    求权法:
        从高位到低位,数据 - 2^(n-1),如果能减,第n位就是1,否则就是0
        137
        128 64 32 16 8 4 2 1
          1  0  0  0 1 0 0 1

手算:
    79 63 121 49

练习1:输入一个正整数以及m,然后显示该正整数的m进制,超过十进制用字母表示

二进制转十进制:
    每位的2^(n-1)求和
    10011010    128+16+8+2 = 154

二进制转八进制:
    每三位二进制位对应一位八进制
    二进制: 1 001 101 110 010
    八进制: 1  1   5   6   2

二进制转十六进制:
    每四位二进制对应一位十六进制
    二进制:  1 1011 0111 1010
    十六进制: 1  B    7    A 

在C语言中:以0开头的数据都是八进制;以0x开头的数据都是十六进制数据
    %o 以八进制形式显示数据
    %x 以十六进制形式显示数据
    %#o %#x 以对应的格式显示不同进制

原码、反码、补码:
原码:
数据的二进制就是原码 -10 10001010
1 - 1
1 + (-1)
0000 0001 + 1000 0001 -> 1000 0010 (-2) x

反码:
    正数的原码就是反码
    负数的的反码是原码除符号位外,其他位按位求反 11110101
    1 - 1
    0000 0001 + 1111 1110 = 1111 1111 -> 1000 0000 -0

补码:所有的数据在内存中都是以补码的形式存储,能解决减法问题,增加了一位-128(原码和反码没有)
    正数的补码就是原码
    负数的补码:
        1.转换成二进制的原码
        2.原码的符号位不变,其他位按位求反
        3.反码+1得到补码
    -127
    1111 1111 -> 1000 0000 -> 1000 0001
       原码         反码         补码
    0x81
    %hd 0000 0000 1000 0001 == 129

补码转数据:
    无符号补码直接转换成十进制
    有符号补码先看最高位是0,说明是正数,也直接转换成十进制
    有符号补码,且最高位是1,说明是负数:
        1.补码-1得到反码
        2.反码的符号位不变,按位求反得到原码
        3.原码转换成十进制
    有符号 1111 1111 -> 1111 1110 -> 1000 0001 -> -1
            补码          反码         原码

位运算符: & | ~ ^ << >>
A & B 按位相与
10101101 0xAD
01101110 0x6E
--------
00101100 0x2C

A | B   按位相或
10101101
01101110
--------
11101111    0xEF

~A      按位求反
10101101
--------
01010010    0x52

A ^ B   按位异或 相同为0,相异为1
10101101
01101110
--------
11000011    0xC3

A << n  把A的补码向左移n位,右边补0,左边丢弃
10101101 << 4
101011010000
------------
11010000    0xD0

A >> n  把A的补码向右移n位,右边丢弃,左边补符号位
10101101 >> 4
111110101101
------------
11111010    0xEA

练习2:输入一个正数,把它的4~7位设置位1010,其他位不变
xxxxxxxx xxxxxxxx xxxxxxxx 1010xxxx
num & ~(0xF<<4) | (0xA<<4)

思考:输入两个正数,把A的4~7位设置为B的3~6位,其他位不变

    A & ~(0xf0) | (B<<1 & 0xf0)
    0

函数:
是一段具有某项功能的代码的集合,是C语言中管理代码的最小单位
把代码分成一个个函数,可以方便地管理和调用代码

函数分类:
    标准库函数:
        C语言管理委员会为C语言以函数形式提供的一套基础功能,被封装在libc.so库中,使用时苦要包含头文件,函数名(参数)即可调用标准库函数
        int atoi(const char *nptr);
        功能:把字符串转换成整数int
        long atol(const char *nptr);
        功能:把字符串转换成整数long

        #include <ctype.h>
        int isalnum(int c);
        功能:判断c是不是数字、字母字符
        int isalpha(int c);
        功能:判断c是不是字母字符
        int isdigit(int c);
        功能:判断c是不是数字字符
        int islower(int c);
        功能:当c是小写字母字符时返回为真
        int isupper(int c);
        功能:当c是大写写字母字符时返回为真
        int toupper(int c);
        功能:把字符转换成大写字符
        int tolower(int c);
        功能:把字符转换成小写字符

         #include <stdlib.h>
        int abs(int j);
        功能:返回j的绝对值


        以下函数被封装在libm.so库中 <math.h> -lm
        double pow(double x, double y);
        功能:求x的y次幂
        double fabs(double x);
        功能:求浮点型数据的绝对值
        double sqrt(double x);
        功能:返回x的平方根
        double floor(double x);
        功能:返回小于等于x的最大整数(向下取整)
        double ceil(double x);
        功能:返回大于等于x的最小整数(向上取整)

        #include <time.h>
        time_t time(time_t *t);
        功能:返回自1970-1-1 0:0:0 到当前时间过了多少秒
            time(NULL)
        
        int system(const char *command);
        功能:调用系统命令

        int rand(void);
        功能:返回一个随机整数

        void srand(unsigned int seed);
        功能:种随机种子

练习3:获取10个范围[100,1001)的随机数

练习4:随机出一注双色球彩票号码
    6个红球: 1~33不能重复
    1个蓝球: 1~16


srand(time(NULL))
for(int i=0; i<10; i++)
{
    printf("%d",rand());
}


    系统函数:
        是操作系统以函数接口形式提供的一套功能,主要有以下功能:
            内存管理、信号处理、文件IO、文件管理、进程管理、进程通信、线程管理、线程同步、网络通信
    
    第三方库函数:
        由第三方提供的,一些开源的或者收费的代码
        MD5 验证
        JSON 序列化与反序列化
        glog 日记记录

    自定义函数:
        为了更好地管理代码,减少冗余把代码封装成函数
        注意:一个函数尽量控制在50行以内,一个函数一个功能

        函数声明:函数声明的目的是为了告诉其他代码该函数的调用格式

            返回值类型 函数名(类型1 形参名1,类型2 形参名2,...);
                1. C语言中函数名全部小写,可以用下划线分隔
                2.如果不需要参数时,建议写void,不要空着
                3.如果不需要返回值,也写void,但是return后不能跟数据

                隐式声明:
                    当调用函数之前没有定义和声明,编译器会猜测函数的格式,参数列表会根据实参(数据)来猜测,返回值会猜测成int类型

                注意:函数定义如果在函数调用之前,可以省略函数声明

        函数定义:
            返回值类型 函数名(类型1 形参名1,类型2 形参名2,...);
            {
                函数体
                return val;
            }

        函数调用:
            函数名(实参1,实参2,...);
            注意:返回值会放在调用的位置,可以立即打印显示,或者也可以用变量记录下来

作业:
1.实现一个函数,判断整数是否为素数,调用该函数显示出100~10000之间所有的素数
2、输入两个日期,计算两个日期之间间隔了多少天
3、实现一个函数,判断整数是否是回文数,调用该函数显示出1亿-10亿之间的所有回文数
4、计算出100的阶乘
5、输入一个整数,显示该整数的补码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值