第07天C语言(00):笔记总结

01-数组-内存存储细节
 变量

     变量在内存中的存储

     由于变量的内存寻址是从大到小,所以存储数据时 会从高字节开始存储

  

  数组

   注意 : 数组的存储 和 变量有点不一样, 数组存储元素, 是从所占用的低字节开始

   其实 数组名 就是 数组的地址
02-数组-注意点
 注意点 : 在使用数组的时候, 一定不要访问 不属于自己的存储空间,这样会导致数据混乱

  有时候如果访问了 不属于自己的存储空间, 程序会报错
03-数组-练习1
 1.从键盘 录入当天出售BTB的价格 并 计算出售 BTB的总价 和 平均价(比如说一天 出售了3个比特币)
04-函数和数组1
 变量

     基本数据类型作为 函数的参数 是 值传递

     如果形参是基本数据类型, 在函数中 修改形参的值 不会影响到外面的值

  

  数组

     注意 : 数组名作为函数的参数传递, 传递的数组的地址

     因为数组名 就是 数组的地址 &number = &number[0] == number

     注意 : 如果数组作为函数的形参, 元素的个数可以省略

     如果形参是数组, 那么在函数中修改形参的值, 会影响到实参的值
05-数组和函数2
 如果传递的数组名称, 其实传递的是地址

  如果传递的地址, 其实传递的是指针

  指针在64 编译环境 占8个字节

  

  注意 : 如果数组作为形参,那么在函数中就不能通过数组的名称 计算出数组元素的个数

  因为系统会自动将 数组形参转换为指针, 指针占用8个字节
06-数组-练习2
 设计一个函数 int arrayMax(int a[], int count) 找出数组元素的最大值
07-数组-练习3
 1.从键盘输入3个0~9的数字,然后输出0~9中 哪些数字没有出现过
08-数组-练习4
 1.要求 从键盘输出 6个0~9的数字,排序后输出
09-选择排序
 已知一个无序的数组,里面有5个元素,要求对数组进行排序

      选择排序: 从小到大

      特点 :

      拿到其中一个元素的值 和 其他元素进行比较, 完全比较完一次之后,最值出现在第0位

      

      倒三角形式

      比如有4个数

      1 比 2\3\4

      2 比 3\4

      3 比 4

      比较次数就是一个倒三角的比较

      ***

      **

     *
10-选择排序舞蹈
 http://www.56.com/u86/v_ODU0ODM5Nzk.html
11-冒泡排序
冒泡排序

  特点

  使用相邻的两个元素进行比较,每完全比较完一次,最值出现在末尾

  规律:倒三角

  ****

  ***

  **

  *
12-排序优化
 #pragma 1. 选择排序

 void selectSort(int nums[],int length)

 {

     for (int i = 0; i <  length -1 ; i++) {

         for (int j = i + 1; j < length; j++) {

             if (nums[i] > nums[j]) {

                 swap(nums, i, j);

             }

         }

         printf("\n");

     }

 }

 #pragma 2.冒泡排序

  

 void bubbleSort(int nums[],int length)

 {

     for (int i = 0; i < 4; i++) {

         for (int j = 0; j < length -1 -i; j++) {

             if (nums[j] > nums[j+1]) {

                 swap(nums, j, j+1);

             }

             

         }

     }

 }

 void swap(int nums[], int i,int j)

 {

     int temp = nums[i];

     nums[i] = nums[j];

     nums[j] = temp;

}
13-折半查找
  折半查找的原理

  1.数组必须是有序的

  2.必须已知min和max(知道范围)

  3.动态计算mid的值,取出mid对应的值 进行比较

  4.如果mid对应的值 大于了 需要查找的值, 那么max要变小 为 mid - 1

  5.如果mid对应的值 小于了 需要查找的值, 那么mix要变大 为 mid + 1
14-折半查找-练习
 现在有一个有序的数组, 要求给定一个数,将该数字插入到数组中,还要保证数组是有序的

 其实就是找到插入需要插入的数字的位置

 其实这个位置就是min的位置
15-进制查表法
 void printfOct2(int value)

 {

     // 1.定义一个数组,用于保存八进制中所有的取值

     char charValue[11] = {'0','1','2','3','4','5','6','7'};

     // 2.定义一个数组,用与保持查询后的结果

     char result[11] = {'0'};

     // 3.定义一个变量,用于记录当前需要存储到查询结果数组的索引

     int pos = 11;

     

     while (value != 0) {

         int res = value & 7;

         // 2.利用取出来的值 到表中查询对应的结果

         char c = charValue[res];

         // 3.存储查询的结果 (从最后一位开始存储)

         result[--pos] = c;

         // 4.移除二进制被取出的三位

         value = value >> 3;

 //        printf("pos = %i\n",pos);

  

     }

     // 4.打印结果

     for (int i = pos; i < 11; i++) {

         printf("%c",result[i]);

     }

     printf("\n");

 }

16-进制查表法-优化
 // 转换所有的进行

 // value就是需要转换的数值

 // base就是需要&上的数

 // offset 就是需要 右移的位数

 void total(int value,int base,int offset)

 {

     // 1.定义一个数组,用于保存十六进制中所有的取值

     char charValue[] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};

     // 2.定义一个数组,用与保持查询后的结果

     char result[32] = {'0'};

     // 3.定义一个变量,用于记录当前需要存储到查询结果数组的索引

     int pos = sizeof(result)/sizeof(result[0]);

  

     

     while (value !=0) {

         // 取出4位的值

         int res = value & base; // 1 7 15

         // 利用这个值 作为索引去数组中 查询对应的十六进制的值

         char c = charValue[res];

         //        printf("%c",c);

         // 将取出来的值 放到用于存储结果的数组中

         result[--pos] = c;

         

         // 每取完一次 就干掉他最低的4位

         value = value >> offset;  // 1 3 4

 //        printf("pos = %i\n",pos);

     }

     

     for (int i = pos; i < 32; i++) {

         printf("%c",result[i]);

     }

     printf("\n");

 }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容