操作符——C语言初阶

news2024/10/7 2:24:16

一.算数操作符:

+        -        *        /        %

  1. +、-、*、/这四个运算符均可用于整数及浮点数的运算。

  2. 当使用/运算符时,如果两个操作数均为整型,那么执行整数除法,运算结果也为整型;如果两个操作数至少一个为浮点数,那么执行浮点数运算,运算结果为浮点型。

  3. %运算符只能用于两个整数相除,返回余数


二.位移操作符:

<<        >>

注:位移操作符的操作数只能是整数

  1. 左移操作符(<<):不论算术移位还是逻辑移位,均将左边的数舍弃,右边空缺位补0(左边丢弃,右边补0)
  2. 右移操作符(>>)

    当进行逻辑移位时,右边位丢弃,左边空缺位补0(右边丢弃,左边补0) ;  当进行算术移位时,右边位丢弃,左边位补原数的符号位(右边丢弃,左边补符号位)。

拓展:

整数的二进制表示有三种——原码反码补码

  1. 正整数的原码,反码补码相同
  2. 负的整数的原码,反码,补码是要计算的
  3. 整数在内存中储存的是补码

(1).例如=>7——由二进制得111,且为正整数(四个字节=32个比特位),所以首位为0

  • 原码:00000000000000000000000000000111
  • 反码:00000000000000000000000000000111
  • 补码:00000000000000000000000000000111

(2)..例如=>-7——由二进制得111,且为负整数(四个字节=32个比特位),所以首位为1

  • 原码:10000000000000000000000000000111(首位为1)
  • 反码:11111111111111111111111111111000(原码的符号位不变,其他位按位取反)
  • 补码:11111111111111111111111111111001(反码+1)

观察代码及其输出结果:

注意:

  1. 移位操作不改变原值。
  2. 移位时不能移负数位,这个是标准未定义的

三.位操作符:

(按位与)       | (按位或)       ^(按位异或)

注:它们的操作数必须是整数

(1)& 按(二进制)位与

例如(观察代码及其结果):

%d意味着打印一个有符号的数

思路如下:

  • 00000000000000000000000000000011—— 3的补码
  • 00000000000000000000000000000101—— -5的原码
  • 11111111111111111111111111111010—— -5的反码
  • 11111111111111111111111111111011—— -5的补码
  • 计算方法(比较二者补码,同零为零,同一为一,二者不同为零,最后转化为原码输出)
  • 00000000000000000000000000000011——按位与结果,正整数原码和补码相等(转化后结果为3)

(2). | 按(二进制)位或

例如(观察代码及其结果):

思路如下:

  • 00000000000000000000000000000011—— 3的补码
  • 00000000000000000000000000000101—— -5的原码
  • 11111111111111111111111111111010—— -5的反码
  • 11111111111111111111111111111011—— -5的补码
  • 计算方法(比较二者补码,只要有一为一,同时为零为零,最后转化为原码输出)
  • 11111111111111111111111111111011——按位或结果
  • 10000000000000000000000000000101——转化为原码,符号位不变(结果为-5)

(3). ^ 按(二进制)位异或

例如(观察代码及其结果):

思路如下:

  • 00000000000000000000000000000011—— 3的补码
  • 00000000000000000000000000000101—— -5的原码
  • 11111111111111111111111111111010—— -5的反码
  • 11111111111111111111111111111011—— -5的补码
  • 计算方法(比较二者补码,相同为零,相异为一,最后转化为原码输出)
  • 11111111111111111111111111111000——按位异或结果
  • 10000000000000000000000000001000——转化为原码,符号位不变(结果为-8)

例题:不能创建临时变量(第三个变量),实现两个数的交换

如下图(交换成功):

代码如下:

//异或操作符支持交换律
#include<stdio.h>
int main()
{
	int a = 3;
	int b = -5;
	printf("交换前:a=%d,b=%d\n", a, b);
	a = a ^ b;//a=3^5
	b = a ^ b;//b=3^5^5      b=3
	a = a ^ b;//a=3^5
	printf("交换后:a=%d,b=%d\n", a, b);
}

四.赋值操作符:

  1. 赋值运算可以修改一个变量的值(=
  2. 复合运算符:+=,-=,*=,%=,>>=,<<=,&=,|=,^=

如下图所示,同理可推理出其他复合运算符的含义


五.单目操作符(只有一个操作数):

  •                逻辑反操作符
  • -                 负值
  •               正值
  •               取地址
  • sizeof         操作数的类型长度(以字节为单位)
  •                对一个数的二进制按位取反
  • --                 前置,后置--
  • ++               前置,后置++
  •                 间接访问操作符(解引用操作符)
  • (类型)     强制类型转换

(上面的操作符基本上前面都已经总结过,除了~)

(1)~(按位取反) 
例题:    对一个数的二进制按位取反 (包括符号位)

例如:

#include <stdio.h>
int main()
{
    int a = -1;
    //根据前面复习的知识点,易得
    //10000000000000000000000000000001 - 原码
    //11111111111111111111111111111110 - 反码
    //11111111111111111111111111111111 - 补码
    int b = ~a; //全部按位取反
    //b的表示应为:
    //00000000000000000000000000000000 
    //故将a按位取反之后赋值给b的值为0
    printf("%d\n", a);
    printf("%d\n", b);
    return 0;
}


(2)sizeof:操作数的类型长度(以字节为单位)

  • sizeof是操作符,不是函数
  • strlen是库函数,是用来求字符串长度
  • sizeof括号中的表达式是不参与运算的


六.关系操作符:

>        <        >=        <=         !=        ==

  1. ==是等于,=是赋值,不要混淆!
  2. !=是不等于,>=是大于等于,<=是小于等于
  3. 关系运算符就是进行比较,结果为真返回1,结果为假返回0

七.逻辑操作符:

  • &&             逻辑与      
  • ||                逻辑或 

  • 截断特性:逻辑与左边为假,右边不在读取计算 , 逻辑或左边为真,右边不在读取计算

(1)&&  逻辑与  

        理解为: 即 怎么  又 怎么 , 一假全假,全真为真

(2)||     逻辑或    

        理解为:   要么 怎么 要么 怎么 , 一真为真, 全假为假


七.条件操作符(三目操作符):

表达式1?表达式2:表达式3;

  1. 有三个操作数
  2. 若exp1假,则输出exp3;若exp1真,则输出exp2


八.逗号表达式:

exp1,exp2,exp3,...expN   

  1. 逗号表达式就是逗号隔开的一串表达式
  2. 逗号表达式的特点是:从左向右依次计算,整个表达式的结果是最后一个表达式的结果


九.下标引用、函数调用和结构成员

(1)下标引用操作符[ ]

  1. 操作数:一个数组名+一个索引值
    int arr[10];//创建数组
    arr[9] = 10;//实用下标引用操作符
    [ ]的两个操作数是arr和9

(2)函数调用操作符( )

  1. 接受一个或多个操作数:第一个操作数是函数名,剩余的操作数就是传递给函数的参数

(3)访问一个结构的成员:

  •               结构体.成员名
  • ->              结构体指针->成员名
  1. 结构体普通变量如何访问结构体成员:C语言规定,结构体的普通成员可以通过运算符“点.”去访问其成员
  2. 结构体指针变量如何访问其成员:可以通过箭头符号的方式去访问其成员
  3. (*p).name = = p -> name 左右两种方式等价
  4. 结构体成员如果是字符串,不能直接通过符号“=”去修改值,可以通过C语言中的拷贝函数strcpy去修改值

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1214018.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Facebook账号运营技巧

Facebook作为全球知名的社交媒体平台之一&#xff0c;坐拥着庞大的用户群体&#xff0c;吸引大量的跨境电商加入&#xff0c;那么肯定就会有少部分的卖家对于Facebook账号运营不是很了解&#xff0c;下面小编将讲一下Facebook账号运营的一些小技巧。 1、明确目标受众 首先需要明…

32 _ 字符串匹配基础(上):如何借助哈希算法实现高效字符串匹配?

从今天开始,我们来学习字符串匹配算法。字符串匹配这样一个功能,我想对于任何一个开发工程师来说,应该都不会陌生。我们用的最多的就是编程语言提供的字符串查找函数,比如Java中的indexOf(),Python中的find()函数等,它们底层就是依赖接下来要讲的字符串匹配算法。 字符串…

【BIM入门实战】Revit图元的选择方式,总有一款适合你

Revit图元的五种常见选择方式,总有一款适合你。 文章目录 一、直接单击二、加选和减选三、连续框选四、按类别选择五、全选过滤选择操作可以在三维视图、平面视图等多种视图中进行。 一、直接单击 直接单击,即可选中某一个图元,如选择一个扶手。 二、加选和减选 按住ctrl键…

37 _ 贪心算法:如何用贪心算法实现Huffman压缩编码?

基础的数据结构和算法我们基本上学完了,接下来几节,我会讲几种更加基本的算法。它们分别是贪心算法、分治算法、回溯算法、动态规划。更加确切地说,它们应该是算法思想,并不是具体的算法,常用来指导我们设计具体的算法和编码等。 贪心、分治、回溯、动态规划这4个算法思想…

数据库表字段以表格形式写入Word

在项目的开发中&#xff0c;难免会有编写概要设计、详细设计文档的要求&#xff0c;而在这些文档中&#xff0c;不可避免的就是要把数据库表的字段信息以表格的形式体现出来。例如下面这种格式 表数量少点还可以一点点粘贴&#xff0c;多了的话真的会疯&#xff0c;所以自己编写…

【计算机网络笔记】DHCP协议

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能&#xff08;1&#xff09;——速率、带宽、延迟 计算机网络性能&#xff08;2&#xff09;…

35 _ Trie树:如何实现搜索引擎的搜索关键词提示功能?

搜索引擎的搜索关键词提示功能,我想你应该不陌生吧?为了方便快速输入,当你在搜索引擎的搜索框中,输入要搜索的文字的某一部分的时候,搜索引擎就会自动弹出下拉框,里面是各种关键词提示。你可以直接从下拉框中选择你要搜索的东西,而不用把所有内容都输入进去,一定程度上…

C++二分查找算法:132 模式解法二枚举2

题目及解法一&#xff1a; https://blog.csdn.net/he_zhidan/article/details/134362273 分析 第一步&#xff0c;选择各3对应的1&#xff0c;如果有多个符合对应最小的1&#xff0c;记录num[0,j)中的最小值iMin&#xff0c;如果nums[j]大于iMin&#xff0c;则m3To1 [nums[j…

认知升级:模型与范式转换

你好&#xff0c;我是 EarlGrey&#xff0c;一名双语学习者&#xff0c;会一点编程&#xff0c;目前已翻译出版《Python 无师自通》、《Python 并行编程手册》等书籍。 点击上方蓝字关注我&#xff0c;持续获取编程干货、好书推荐和高效工具分享&#xff0c;一起提升认知和思维…

excel中正态分布函数NORM.DIST和NORMDIST,以及它们之间的区别

NORM.DIST和NORMDIST的区别 NORM.DIST和NORMDIST函数都可以返回正态分布的概率密度、或者正态累积分布。 根据微软官网上的说法&#xff0c;NORMDIST函数已经不建议使用了&#xff0c;它已经被一个或者几个新的函数代替&#xff08;例如NORM.DIST&#xff09;&#xff0c;这些…

Rust图形界面编程:egui平直布局

文章目录 平直布局with_layout 平直布局 在前面的示例中&#xff0c;已经用到了ui.horizontal用来布局&#xff0c;其特点是水平摆放控件。相应地&#xff0c;ui.vertical则是垂直摆放控件。根据控件的摆放顺序不同&#xff0c;这两个布局组件衍生出一系列布局函数 horizonta…

深入Rust:探索所有权和借用机制

大家好&#xff01;我是lincyang。 今天&#xff0c;我们将一起深入探索Rust语言中的一个核心概念&#xff1a;所有权和借用机制。 这些特性是Rust区别于其他语言的重要特点&#xff0c;它们在内存管理和并发编程中扮演着关键角色。 一、Rust所有权机制 1. 什么是所有权&#x…

Java --- JVM之StringTable

目录 一、String的基本特性 二、String的内存分配 2.1、String内存分布图 三、字符串拼接操作 3.1、字符串拼接操作底层原理 3.2、拼接操作与append操作效率对比 四、intern()方法 4.1、intern()效率 五、StringTable的垃圾回收 一、String的基本特性 1、String字符…

C++二分查找算法:数组中占绝大多数的元素

题目 设计一个数据结构&#xff0c;有效地找到给定子数组的 多数元素 。 子数组的 多数元素 是在子数组中出现 threshold 次数或次数以上的元素。 实现 MajorityChecker 类: MajorityChecker(int[] arr) 会用给定的数组 arr 对 MajorityChecker 初始化。 int query(int left, …

【算法】区间(差分约束)

题目 给定 n 个区间 [ai,bi] 和 n 个整数 ci。 你需要构造一个整数集合 Z&#xff0c;使得 ∀i∈[1,n]&#xff0c;Z 中满足 ai≤x≤bi 的整数 x 不少于 ci 个。 求这样的整数集合 Z 最少包含多少个数。 输入格式 第一行包含整数 n。 接下来 n 行&#xff0c;每行包含三个…

21 Linux 自带的LED驱动

一、Linux 自带 LED 驱动使能 其实 Linux 内核自带 LED 抢夺那个&#xff0c;但在此之前需要配置 Linux 驱动来使能 LED 驱动。 输入以下命令&#xff1a; cd linux/atk-mpl/linux/my_linux/linux-5.4.31 make menuconfig 根据以下路径找到 LED 驱动&#xff1a; → Device D…

622.设计循环队列(LeetCode)

思路 先确定什么情况为空&#xff0c;什么情况为满。 这里有两种解决方案&#xff0c; 1.留一个空间空置&#xff0c;当rear1 front时 &#xff0c;则队列为满 &#xff08;这里我们选用方案一&#xff09; 2.增加一个size变量记录数据个数&#xff0c;size 0则为空&#xff…

asp.net数字档案管理系统VS开发sqlserver数据库web结构c#编程web网页设计

一、源码特点 asp.net 数字档案管理系统 是一套完善的web设计管理系统&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为vs2010&#xff0c;数据库为sqlserver2008&#xff0c;使用c#语 言开发。 asp.net数字档案系统1 应用技…

通过右键用WebStorm、Idea打开某个文件夹或者在某一文件夹下右键打开当前文件夹用上述两个应用

通过右键用WebStorm、Idea打开某个文件夹或者在某一文件夹下右键打开当前文件夹用上述两个应用 通过右键点击某个文件夹用Idea打开 首先打开注册表 win R 输入 regedit 然后找到HKEY_CLASSES_ROOT\Directory\shell 然后右键shell 新建一个项名字就叫 Idea 第一步&#xf…

【FPGA】zynq 单端口RAM 双端口RAM 读写冲突 写写冲突

RAMRAM读写分类RAM原理及实现RAM三种读写模式不变模式写优先读优先 单端口 RAM伪双端口 RAM真双端口 RAM读写冲突和写写冲突读写冲突写写冲突总结&#xff1a; RAM RAM 的英文全称是 Random Access Memory&#xff0c;即随机存取存储器&#xff0c;简称随机存储器&#xff0c;…