初入C语言殿堂,小白的从零开始学代码,旁人勿入(只会浪费你时间)

2024-03-25 13:10

本文主要是介绍初入C语言殿堂,小白的从零开始学代码,旁人勿入(只会浪费你时间),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先介绍一下游戏背景:一个肥宅,怒闷的问自己为什么没有女生看得上为什么出生没有含着金钥匙为什么自己一无是处,于是他走上了攀登C语言圣山的无尽旅途…

第一篇:新手村:一望无际的C圣殿山顶。

一.新手大礼包

或许是前世转世给造物主充了钱,肥宅还未踏入新手村就在路上捡到了大礼包。他打开一看,哇,暴率是真的高:


转义字符

\0为字符串的结束标志,\t为空格 \ddd 为1~3个八进制的数字()。xdd为2个十六进制的数字,\'为输出单引号,\"为输出双引号。

例子:

printf("%d\n", strlen("c:\test\328\test.c"));

结果输出14。分析:共{'c', ':', '\t', 'e', 's', 't', '\328', '\t', 'e', 's', 't', '.', 'c', '\0'}共14个字符

循环语句

判断语句内为执行语句时,先执行,然后判断执行语句所操作的值(个人理解为左值优先,没有左值判断右值(虽然C语言好像没有右值概念))是否为0
例子:

int i = 0;
int k = 0;
for(i = 0, k = 0; i++, k++)k++;
...

for循环执行了0次,因为中间为判断语句,先执行再判断,将k值赋0后,判断k的值是否为0,为0则跳出循环。这一段代码中k一直都是0,没出生过(bushi)。
这又带来了一个问题,如果判断语句中写一个没有返回值的函数,它会如何做判断呢?使用C++(QT)试了试,结果如下
在这里插入图片描述

生成随机数

生成随即数的函数int rand(void),来自头文件<stdlib.h>,需要void srand(unsigned inte seed)先设置随即生成函数的规则,输入不随程序影响,一直变换的值就能得到随机数(比如时间戳)

system函数

system()括号内跟shell命令等同于跟系统终端输入命令

strcmp函数

bool strcmp(char a, char b)比较a,b是否相同,相同返回0

goto语句

例子:

n:...;
goto n;

goto语句不能跨函数跳转。

对于多重循环要一次性跳出多个循环的时候才显的好用(其他时候不该用(不然你的领导会吃了你的)):

for(...){for(...){for(...){...if(disater)goto error;}}...error:if(disater)//处理错误情况
}

字符数组初始化

char arr1[] = "abc";为字符串初始化,最后会有\0字符,所以初始化为4字符数组,最后一个值为\0

char arr2[3] = {'a', 'b', 'c'};为传值初始化,传入3个字符参数,所以初始化为3字符数组。

查看地址值可以用%p参数,例如 printf("&arr[%d] = %p\n", i, &arr[i]);

数组名的地址值是什么

void arr(int arr[]){int sz = sizeof(arr) / sizeof(arr[0]);printf("%d", sz); //1
}
int main(){int arr[10];int sz = sizeof(arr) / sizeof(arr[0]);printf("%d", sz); //2arr(arr);
}

1处打印值为1,2处打印值为10。为什么会有不同?:

int sz = sizeof(arr) / sizeof(arr[0]);中,sizeof(arr)中的arr不同与一般理解!arr表示的是整个数组的指针,除此之外只有&arr也是这样,可以这么说,&arr + 1 - arr[0]为10个元素类型长度的值而非1个。所以sizeof(arr)没有问题。

问题在与函数声明的型参上。arr(int arr[])本质上和arr(int* arr)一样为指针类型,因此在sizeof()中不认为是数组类型,因此只返回一个元素的大小。而在主函数中arr定义为数组,所以能打印出正确的值。(型参可以改为arr(&int arr[])这样在函数内部也能认为是数组)(存疑)

算术操作符中%的规则

例如 10%3符号两边必须为整数,不能是浮点数,返回取余后的值,操作的是二进制位

移位操作符号 << 、 >>

左移右移右边的值都只能是正整数,负数没有定义

左移操作符 <<

左边抛弃,右边补0,不赋值不会使变量发生变化。

右移操作符 >>

有两种方式,取决于编译器

第一种算术右移,左边补原来位数的值(1则补1,0则补0),右边抛弃

第二种逻辑右移,左边补0,右边抛弃

位操作符

如何仅用位操作符来完成两个数的交换
a = a ^ b;
b = a ^ b;
a = a ^ b;

可以这样来理解:

b = a ^ b即为b = (a') ^ b = a ^ b ^ b = a ^ (b ^ b) = a

a = a ^ b即为a = (a') ^ (b') = (a ^ b) ^ (a) = b ^ (a ^ a) = b

相关练习(巩固)

判断整数(32位)有多少个二进制位1,高级做法:(不明觉厉啊!)

whil(num){++count;num &= (num - 1);
}

num &= (num - 1)相当于做了判断二进制数组中最靠右的1在哪里同时去掉了比这个1更右的位数(左补齐0),进而循环判断num就能通过循环次数得出结果。

单目操作符

~对一个数的二进制位按位取反

++a (–a) 先a’=a+1,后b=a’,另一种理解为return(a+1)

a++ (a–) 先b=a, 后a=a+1,另一种理解为return a, a=a+1;

sizeof是操作符,可以sizeof int但是对于struct student不适用,因为sizeof优先级很高

逻辑操作符中的特例

&& 若左边为0,右边全忽视(当然要考虑到符号执行顺序的问题)

|| 若左边为1,右边全忽视

逗号操作符号,

…,…,…;这条语句最后返回的结果为最后执行(即最后一个小语句)的结果。

算术表达式中的强制转换

整形提升

按照最高位的符号位(0或1)来提升(左补齐),不足整形提升为整体(长度)。

只要参与了表达式运算(包括逻辑运算),就会发生 整形提升

寻常算术转换

赋值时,赋值前的变量会尝试转换为赋值后的。

计算时,底精度的会转换成高精度的。(有符号数比无符号数精度底)

操作符的执行顺序

对于考操作符的题目,就尽量按照 顺序,结合性,是否改变操作性来判断,只要结果相等,不需要完全的判断唯一路径。

但对于写代码时,不要写不能确定唯一路径的算式

例子 a * b+c * d+e * f 这样只根据三原则定理是无法判断出唯一路径的

指针的大小

在32位系统为4字节,64位系统为8字节

指针类型的意义

不同的指针类型的步长是不一样的(*p+1),这意味着不同类型的指针能操作的字节空间数的权限是不一样的。字节是地址,但对于递归时的指向性(下一个地址值指向哪里)是有指针类型决定的

指针减去指针

前提是指针类型一致且处在同一块连续的空间(比如数组)

返回相隔元素的个数(可以小指针减大指针,为负数)

另:标准规定,对于比较而言,可以允许与数组最后一个元素的指针的后一个元素(指针尾)进行比较,而对于第一个元素的指针的前一个指针则没允许的规定

结构体的声明

三步走:

typedef struct Stu{int num;char name;
}Stu; //后可跟初始化,例如: = {1,"richard"}

定义:

struct Stu p1; // 初始化使用大括号

结构体传参最好传结构体指针


肥宅这真是捡到宝,拿着这个包直接闭关,十年之后又是一条好汉!

这篇关于初入C语言殿堂,小白的从零开始学代码,旁人勿入(只会浪费你时间)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/845117

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return