✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改 ---- 文章目录 了解关键字分类 关键字及其说明 理解变量、定义与声明...三个关键字 最宽宏大量的关键字- auto 变量的分类——补充内容 变量的作用域—— 补充内容 变量的生命周期——补充内容 auto 相关 最快的关键字—— register 最名不符实的关键字 —static...修饰变量 结语 了解关键字分类 C语言一共多少个关键字呢?...一般的书上,都是32个(包括本书),但是这个都是 C90(C89) 的标准。其实 C99 后又新增了5个关键字。...不过,目前主流的编译器,对 C99 支持的并不好,我们后面默认情况,使用 C90 ,即认为32个 关键字及其说明 auto 声明自动变量 short 声明短整型变量或函数 int
};//十个数的无序数列 int i,j,t; printf("此程序使用冒泡排序法排列无序数列!...} } printf("排列好的字符组是:\n"); //输出排列好得吃数列 for(i=0;i<10;i++) { printf("%c...{ printf("%c ",a[i]); } return 0; } void function(char a[],int m) { //冒泡排序...:也叫升序排序法,但是相比起二分法查找只能应用于有序数列,二如何将一个无序数列变的有序就可以使用冒泡排序法!!!...对上面的过程进行总结: 该思想体现在成续上的解法是: 实例: 冒泡排序不仅仅可以应用于数字同样可以应用于字符字母的快速排序: 心得体会: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人
C语言-链表排序 题目描述 已有a、b两个链表,每个链表中的结点包括学号、成绩。要求把两个链表合并,按学号升序排列。 输入 第一行,a、b两个链表元素的数量N、M,用空格隔开。...=NULL){ p=p->next; } p->next=b->next; return a; } void linksort(struct student *p){ //排序 int tnum
关键字的分类 C语言一共多少个关键字呢?一般的书上,都是32个,但是这个都C90(C89) 的标准。其实 C99 后又新增了5个关键字。...不过,目前主流的编译器,对 C99 支持的并不好,默认使用 C90 ,即,认为32个。...关键字 说明 auto 声明自动变量 short 声明短整型变量或函数 int 声明整型变量或函数 float 声明长浮点型变量或函数 double 声明双精度变量或函数 char 声明字符型变量或函数...因为不需要从内存里读取数据了 其实该关键字,不用管,因为现在的编译器,已经很智能了,能够进行比人更好的代码优化 三、最名不符实的关键字 - static 作用:修饰变量和函数 注: 全局变量,是可以跨文件...有符号整数 vs 无符号整数 signed : 第一位为符号位 unsigned :无符号位 代码演示: char a = 20; char b = -10; unsigned char c
(附)C语言关键字表 关键字 说明 auto 声明自动变量 break 跳出当前循环 case 开关语句分支 char 声明字符型变量或函数返回值类型 const 声明只读变量 continue...声明共用体类型 void 声明函数无返回值或无参数,声明无类型指针 volatile 说明变量在程序执行中可被隐含地改变 while 循环语句的循环条件 _Packed 指定结构、联合和枚举类型的对齐方式 类型关键字...char double enum float int long short signed struct union unsigned void 控制语句关键字 break case continue...default do else for goto if return switch while 存储类关键字 auto extern register static volatile 其他关键字 const
碎碎念念 快速排序的基本思想是:首先找一个基准数,一般选第一个数或者最后一个数作为基准数,然后先把这一串数以基准数为界限分成两部分,一部分比基准数小,另一部分比基准数大。...代码 #include void fast(int array[],int first,int end)//从小到大排序。...{ if(first>=end)//相同说明这小部分一排序完毕。...[10]={1,2,5,10,2,8,7,7,6,3}; fast(array,0,9); for(int i=0;i<10;i++) printf("%d ",array[i]); } 快速排序是冒泡排序的进化版...,数多时比冒泡排序少了交换次数。
#include int main() { int a[10]; int i, j; int temp; printf("请输入10个整数:"); ...
C语言排序算法-冒泡排序 从键盘输入的10个整数按从小到大的顺序排序后输出 #include void main() { int n[10] = { 25,35,68,79,21,13,98,7,16,62...:\n"); for (i = 0; i < 10; i++) printf("%-4d", n[i]); printf("\n"); } 运行的结果如下: 为了更加清晰,准确的理解冒泡排序的过程...,现在修改上面的程序,每次排序之后都会进行一次输出。...相邻两个数如果逆序,则交换位置 { temp = n[j]; n[j] = n[j + 1]; n[j + 1] = temp; } } printf("第%d趟排序完成后的数据排序...10; i++) printf("%-4d", n[i]); printf("\n"); } 运行结果如下: 其实很好理解的,就是for循环的嵌套,尤其是理解每一层循环的意思,初学者多研究一下
但是大家在使用的时候,一个一个去排序太麻烦了,这一期我将带给大家是利用冒泡排序完成二分查找法的高效方法 一.先要写出主函数数组内容,方便传值给排序函数 int main() { int left...,不懂的可以看一下【C语言】冒泡排序+优化版,我的上一篇文章,里面有细讲冒泡排序和优化,然后我们现在传址进去进行排序。...) { int mid=(left+right)/2; if(m_arr[mid]<m_c) { left=mid+1; } if(m_arr...[mid]>m_c) { right=mid-1; } if(m_arr[mid]==m_c) { printf("查到了下标:%d",mid...); } } if(left>right) { printf("没查到"); } return 0; } 二分查找不懂的可以看一下【C语言】二分查找算法,讲的非常的详细
例100:C语言实现希尔排序。 解题思路:希尔排序是插入排序的一种又称缩小增量排序,是直接插入排序算法的一种更高效的改进版本,希尔排序是非稳定排序算法。...希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。 ...C语言源代码演示: #include//头文件 int main()//主函数 { void shsort(int s[],int n); //函数声明 int array[11...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线 C语言开发工具 VC6.0、Devc++、VS2019使用教程...更多案例可以go公众号:C语言入门到精通
思路 对于一串待排序的数字,假如是要升序排序,那么先在这串数字中找到最小的那一个放在第一位,然后再在剩下的数字中找到最小的放在第二位,以此类推,完成排序。 那么怎么知道哪个是最小的呢?...=0) printf(" "); printf("%d",num[i]); } } 快速排序 https://blog.csdn.net/weixin_62264287/article/details
“要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例83:C语言用选择排序对10个数进行排序。...解题思路:选择排序是指第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾,,直到全部待排序的数据元素的个数为零...C语言源代码演示: #include//头文件 int main()//主函数 { int i,j,temp,array[11];//定义变量 printf("请输入10
碎碎念念 希尔排序是插入排序的一种,是直接插入排序的改进版。...直接插入排序的优势 从直接插入排序的思想可以知道,如果这堆数原本就比较有序了,那么直接插入排序是非常高效的,因为交换次数会少很多。...希尔排序 基于直接插入排序的这两个特点,我们引入了它的升级版——希尔排序。 希尔排序又被称作缩小增量排序。...为了解决直接插入排序交换距离过长问题,我们设想如果能让这一堆待排序的数中比较小的数在一边,比较大的数在另一边,那么发生交换的时候就不用跨过千山万水了。...,这一堆数已经相对有序了,直接插入排序这个时候就十分高效了。
创作者~周榜126﹣总榜960⇿全网访问量30w+ 本文由 謓泽 原创 CSDN首发如需转载还请通知⚠ 个人主页-謓泽的博客_CSDN博客 欢迎各位→点赞 + 收藏⭐️ + 留言 系列专栏-【C语言...】关键字_謓泽的博客-CSDN博客 ✉️我们并非登上我们所选择的舞台,演出并非我们所选择的剧本 ⑥ continue ⇿ 跳 回 ⒈描述 ⇨ 在C语言当中的 continue 和 break 语句是有一些类似的...这是 continue 和 break 语句最本质的区别,也是我们去学习 continue 关键字的重点。虽说它没有 break 语句那么被经常使用,但是在一些场合特定的情况它的作用是很大的。...⒊注意 ⇨ 很多刚学C语言初学者可能会不明白这两个关键字 continue 语句和 break 语句,其实这两个语句本质上都是非常容易理解的。
union 关键字的用法与struct 的用法非常类似。...在C++里,union 的成员默认属性页为public。union 主要用来压缩空间。如果一些数据不可能在同一时间同时被用到,则可以使用union。...上述问题似乎还比较简单,那来个有技术含量的:请写一个C 函数,若处理器是Big_endian 的,则返回0;若是Little_endian 的,则返回1。...参考答案如下: int checkSystem( ) { union check { int i; char ch; } c;...c.i = 1; return (c.ch ==1); } 现在你可以用这个函数来测试你当前系统的存储模式了。
创作者~周榜126﹣总榜960⇿全网访问量30w+ 本文由 謓泽 原创 CSDN首发如需转载还请通知⚠ 个人主页-謓泽的博客_CSDN博客 欢迎各位→点赞 + 收藏⭐️ + 留言 系列专栏-【C语言...】关键字_謓泽的博客-CSDN博客 ✉️我们并非登上我们所选择的舞台,演出并非我们所选择的剧本 ⑦ default ⇿ 匹配失败 ⒈描述⇢通常用作于 switch case 语句中的 defalut...代码示例演示如下① #include int main(void) { int i = 3; switch (i) { case 1: printf("C1");..."); case 2: printf("C2"); } return 0; } 运行结果 謓泽C1C2 代码解释-这个代码和上面一个代码很像只不过改变了 default 关键字的位置...我们需要注意一点不是执行 default 关键字就就退出了,它依旧会执行下面的语句,因为这个代码 default 语句在 case 语句的前面。
C89 / ANSI C 1989年,由ANSI发布,32个 auto break case char const continue default do double else enum extern...register return short signed sizeof static struct switch typedef union unsigned void volatile while C89...C90 1990年,被ISO和IEC采纳,ISO/IEC 9899:1990 C99 ISO/IEC 9899:1999,新增5个 inline restrict _Bool _Complex _Imaginary...C11 ISO/IEC 9899:2011,新增7个 _Alignas _Alignof _Atomic _Static_assert _Noreturn _Thread_local _Generic
创作者~周榜109﹣总榜883⇿全网访问量35w+ 本文由 謓泽 原创 CSDN首发如需转载还请通知⚠ 个人主页-謓泽的博客_CSDN博客 欢迎各位→点赞 + 收藏⭐️ + 留言 系列专栏-【C语言...】关键字_謓泽的博客 ✉️我们并非登上我们所选择的舞台,演出并非我们所选择的剧本 ⑩② extern ⇿ 外部声明 ⒈描述⇢extern 变量称之为外部存储变量。...test.c 文件 #define _CRT_SECURE_NO_WARNINGS 1 #include extern Add(int x, int y); int main(void...{ int x = 20; int y = 30; int ret = Add(x, y); printf("ret = %d\n", ret); return 0; } Add.c文件...拓展⇢一般来说用包括的是C语言当中的头文件或者是库函数当中的头文件," "是自己使用自己所自定义的头文件[约定俗称的规矩],实际上.c源文件,我们只需要在.h头文件当中加上去就可以了。
创作者~周榜126﹣总榜960⇿全网访问量30w+ 本文由 謓泽 原创 CSDN首发如需转载还请通知⚠ 个人主页-謓泽的博客_CSDN博客 欢迎各位→点赞 + 收藏⭐️ + 留言 系列专栏-【C语言...那么举个例子吧(生活当中的一些依据)有些数据是可变的比如我们的年龄、工资等...那么有些数据是不能变的,你的亲生父母、血型等等...那么如果我们要用C语言描述的话就有这两个知识点常量 const 和变量了...拓展知识点⇢原因是在不同的编译器下对于C语言的支持标准都是不一样的。有的是基于支持标准C语言并且是可以在特定的平台下做扩展的。所以我们需要尽可能地保证使用标准C语言在这样子跨平台就显现出来它的好处了。...[const]修饰数组⇢在C语言中 const 还可以修饰数组,示例代码如下 const int Array[] = {1,2,3,4,5,6,7,8,9,10}; int const Array[]...注-在C语言用 const 修饰指针注意以下两点如下。 ⒈用来限定指向空间的值是不可修改的。 ⒉限定指针式不可修改的。
创作者~周榜126﹣总榜960⇿全网访问量30w+ 本文由 謓泽 原创 CSDN首发如需转载还请通知⚠ 个人主页-謓泽的博客_CSDN博客 欢迎各位→点赞 + 收藏⭐️ + 留言 系列专栏-【C语言...1个字节,%c 所对应的是打印字符的格式数据,有符号(signed)的char取值范围是『 (负)128 ~ 127』无符号字符unsigned char的取值范围是『0~255』 ⒉作用 ⇨ 定义一个字符型变量的方法是使用关键字... char,例如: char str = 'A'; ⒊注意 ⇨ 字符数据在内存中存储的是字符的 ASCll 码,即使是一个无符号整数,其形式与整数的存储形式一样,因为在C语言的字符型数据与整形数据之间通用...⒋实际上字符型是被称之为整形字符类型('单引号')如果不相信的话,你可以用sizeof关键字求下单引号字面值、常量看下它所在的字节大小是不是一个整形(④字节)的。...⒌拓展知识点 ⇨ 相信学习过C++语言的小伙伴应该知道在C++语言当中它还是一个字节的。
领取专属 10元无门槛券
手把手带您无忧上云