码迷,mamicode.com
首页 > 移动开发 > 详细

iOS阶段学习第六天笔记(数组)

时间:2016-07-19 09:53:38      阅读:246      评论:0      收藏:0      [点我收藏+]

标签:

                                                                                              iOS学习(C语言)知识点整理

一、整型数组

 1)概念:一组类型相同,空间连续分布的数据。

 2)int a[10] int 型里面有10个元素,数组的名字叫a, a还是数组的首地址 。

 3)引用数组中的元素 a[i]:数组名+下标,下标从0开始 。

 4)数组元素个数刚好与数组长度相当叫完全初始化。

 5)数组的遍历即访问数组里面的所有元素。

 6)元素的地址 &a[0] 取地址符+数组名+下标

 7)遍历输入,访问不能越界,越界编译器检查不了,有较大的安全风险

 8)int 数组的sizeof等于数组长度乘4

 9)部分初始化后面省略部分全部赋值为0.

10)int a[5]={0} ;int a[5]={}; 部分初始化,全零补齐数组

11)数组的最大下标为数组的长度减一  例如:int a[]={1,2,3,4,5}  len=sizeof(a)/sizeof(int); 最大下标为 len-1。

12)数组长度[ ]里面只能是常量,符号常量

13)数组的初始化

    ①. Int list[5]={2,13,58,55,19};//一般写法

    ②. Int list[5]={6,17};//只对前两个元素赋值

    ③. Int list[5]={[3]=25,[4]=51};//对指定的元素赋值,这里为第三个和第四个

    ④. Int list[]={11,12,13}.//正确,右边的元素确定,则个数可以省略这里为3个。

    ⑤. Int list[];//错误,编译器无法知道应该分配多少的存储空间

    ⑥. Int list[5]; list ={17,18,19,20,21};//错误,只能在定义数组时这样进行初始化

    ⑦. Int list[‘A’]={1,2,3};//正确,相当于是ages[65]

    ⑧. Int count=5;int list[count];//如果不进行初始化,则这种写法正确,编译器不会报错为其分配20个字节的存储空间,

         list[0]=1; list[1]=2;可以像这样对数组的元素进行赋值,但是2,3,4等元素的值时不确定的。 

    ⑨. 而int count=5;int list[count]={1,2,3,4,5};//这种写法是错误的,在定义数组时对数组进行初始化,元素的个数必须为

         常量或者不写,不能是一个变量

      

14)斐波拉契数列  1,1 ,2 ,3 ,5 ,8 ,13 ,21 ,34...

实现代码:

技术分享
 1 int main(){
 2    int arr[20]={};
 3     for (int i=0; i<20; i++) {
 4         if(i<=1)
 5             arr[i]=1;
 6          else
 7           arr[i]=arr[i-1]+arr[i-2];
 8     }
 9     for (int i=0; i<20; i++) {
10         printf("%d ",arr[i]);
11     }
12     return 0;
13  }
技术分享

二、排序

1)选择排序:每次从无序数列选择一个最小的,放在有序队列的后面

      例如:int a[]={12,3,556,0,9,78};

      1. 0]3,556,12,9,78

      2. 0,3],556,12,9,78

      3. 0,3,9]12,556,78

      4. 0,3,9,12]556,78

      5. 0,3,9,12,78]556

实现代码:

技术分享
 1  int main(){
 2     int a[]={12,3,556,0,9,78};
 3     int len = sizeof(a)/sizeof(int);
 4     int k;//纪录最小数的下标
 5     int temp;
 6     //一共要排len-1次
 7     for(int i=0;i<len-1;i++){
 8         //从a[i]~a[len-1]里面找出最小的值,放到a[i]的位置
 9         k=i;
10         for(int j=i+1;j<len;j++){
11             if(a[j]<a[k]){
12                 k=j;
13             }
14         }
15 
16         //a[k]和a[i]做一次交换
17         if(k!=i){
18             temp = a[k];
19             a[k] = a[i];
20             a[i] = temp;
21         }
22     }
23 
24     for(int i=0;i<len;i++){
25         printf("%d ",a[i]);
26     }
27       return 0;
28    }
技术分享

 2)冒泡排序:大数往下沉,小数往上浮

  比较相邻的元素。如果第一个比第二个大,就交换他们两个。

  int a[]={12,3,556,0,9,78};

 一轮比较,需要5次

 1.1  [3,12],556,0,9,78

 1.2  3,[12,556],0,9,78

 1.3  3,12,[0,556],9,78

 1.4  3,12,0,[9,556],78

 1.5  3,12,0,9,[78,556]->一轮结束,最大的一个数沉入底部排序

 实现代码:

技术分享
 1 int main()
 2 {
 3     int a[]={12,3,556,0,9,78};
 4     int temp;
 5     int len = sizeof(a)/sizeof(int);
 6     //排len-1次
 7     for(int i=0;i<len-1;i++){
 8         //无序的数列:a[0]~a[len-1-i],逐对比较
 9         //前面>后面,就交换
10         //i=0,最后一对: a[len-2],a[len-1]
11         for(int j=0;j<len-1-i;j++){
12             if(a[j]>a[j+1]){
13                 temp = a[j];
14                 a[j] = a[j+1];
15                 a[j+1] = temp;
16             }
17         }
18     }
19 
20     for(int i=0;i<len;i++){
21         printf("%d ",a[i]);
22     }
23     return 0;
24 }
技术分享

3)插入排序

 int a[]={12,3,556,0,9,78};

 初始化 12[3,556,0,9,78]

 1. 3,12[556,0,9,78]

 2. 3,12,556[0,9,78]

 3. 0,3,12,556[9,78]

 4. 0,3,9,12,556,[78]

 5. 0,3,9,12,78,556

 {12,33,556,0,9,78}

 实现代码:

技术分享
 1  int main()
 2  {
 3     int a[]={12,3,556,0,9,78};
 4     int len =  sizeof(a)/sizeof(int);
 5     int insert = 0;
 6     //一共要比较len-1次
 7     for(int i=0;i<len-1;i++){
 8         //把a[i+1] 插入到 前面有序数列a[0]~a[i]
 9         insert = a[i+1];
10         for(int j=0;j<=i;j++){
11             if(a[j]>insert){
12                 //插入a[j]这个位置
13                 //后移a[j]~a[i]后移一个
14                 printf("insert %d,pos = %d\n",insert,j);
15                 for(int k=i;k>=j;k--){
16                     a[k+1]=a[k];
17                 }
18                 //插入位置填入insert
19                 a[j]= insert;
20                 break;
21             }
22         }
23 
24         for(int ii=0;ii<len;ii++){
25             printf("%d ",a[ii]);
26         }
27         printf("\n");
28     }
29 
30     for(int ii=0;ii<len;ii++){
31         printf("%d ",a[ii]);
32     }
33     return 0;
34 }
技术分享

三、字符数组

 1)计算字符数组的有效长度用strlen(数组名)

2)实例:

  小写转大写 实现代码:

技术分享
 1 int main(){
 2   char str[10]={h,e,l,l,o};
 3   int len = (int)strlen(str);
 4    //小写转大写
 5      for(int i=0;i<len;i++){
 6          if(str[i]>=a&&str[i]<=z){
 7              str[i] = str[i]- (a-A);
 8          }
 9      }
10   printf("%s",str);
11  
12   return 0;
13 }
技术分享

四、二维数组

 1)实例:

利用二维数组打印杨辉三角

 1

 1  1

 1  2  1

 1  3  3  1

 1  4  6  4  1

 1  5  10 10 5 1

 实现代码:

技术分享
 1  int main(){
 2     int a[10][10];
 3     for(int i=0;i<10;i++){
 4         for(int j=0;j<=i;j++){
 5             if(j==0||i==j)
 6                a[i][j]=1;
 7              else
 8                 a[i][j]=a[i-1][j]+a[i-1][j-1];
 9         }
10     }
11 
12     for(int i=0;i<10;i++){
13         for(int j=0;j<=i;j++){
14             printf("%5d",a[i][j]);
15         }
16         printf("\n");
17     }
18     return 0;
19 }
技术分享

五、不使用第三方变量实现数据交换

实现代码:

技术分享
1 int main(){
2   int a=20,b=30;
3   a=a+b;
4   b=a-b;
5   a=a-b;
6   printf("a=%d;b=%d",a,b);
7 
8   return 0;
9 }
技术分享

 



如果您觉得阅读完本文对您有帮助,请点一下“推荐”按钮,您的推荐将是我写作的最大动力;本文版权归作者和博客园共有,来源网址:http://www.cnblogs.com/ChinaKingKong/欢迎各位转载,但未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接否则保留追究法律责任的权利。

iOS阶段学习第六天笔记(数组)

标签:

原文地址:http://www.cnblogs.com/androidshouce/p/5683435.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!