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...

实现代码:

 int main(){
int arr[]={};
for (int i=; i<; i++) {
if(i<=)
arr[i]=;
else
arr[i]=arr[i-]+arr[i-];
}
for (int i=; i<; i++) {
printf("%d ",arr[i]);
}
return ;
}

二、排序

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

实现代码:

  int main(){
int a[]={,,,,,};
int len = sizeof(a)/sizeof(int);
int k;//纪录最小数的下标
int temp;
//一共要排len-1次
for(int i=;i<len-;i++){
//从a[i]~a[len-1]里面找出最小的值,放到a[i]的位置
k=i;
for(int j=i+;j<len;j++){
if(a[j]<a[k]){
k=j;
}
} //a[k]和a[i]做一次交换
if(k!=i){
temp = a[k];
a[k] = a[i];
a[i] = temp;
}
} for(int i=;i<len;i++){
printf("%d ",a[i]);
}
return ;
}

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]->一轮结束,最大的一个数沉入底部排序

实现代码:

 int main()
{
int a[]={,,,,,};
int temp;
int len = sizeof(a)/sizeof(int);
//排len-1次
for(int i=;i<len-;i++){
//无序的数列:a[0]~a[len-1-i],逐对比较
//前面>后面,就交换
//i=0,最后一对: a[len-2],a[len-1]
for(int j=;j<len--i;j++){
if(a[j]>a[j+]){
temp = a[j];
a[j] = a[j+];
a[j+] = temp;
}
}
} for(int i=;i<len;i++){
printf("%d ",a[i]);
}
return ;
}

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}

实现代码:

  int main()
{
int a[]={,,,,,};
int len = sizeof(a)/sizeof(int);
int insert = ;
//一共要比较len-1次
for(int i=;i<len-;i++){
//把a[i+1] 插入到 前面有序数列a[0]~a[i]
insert = a[i+];
for(int j=;j<=i;j++){
if(a[j]>insert){
//插入a[j]这个位置
//后移a[j]~a[i]后移一个
printf("insert %d,pos = %d\n",insert,j);
for(int k=i;k>=j;k--){
a[k+]=a[k];
}
//插入位置填入insert
a[j]= insert;
break;
}
} for(int ii=;ii<len;ii++){
printf("%d ",a[ii]);
}
printf("\n");
} for(int ii=;ii<len;ii++){
printf("%d ",a[ii]);
}
return ;
}

三、字符数组

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

2)实例:

小写转大写 实现代码:

 int main(){
char str[]={'h','e','l','l','o'};
int len = (int)strlen(str);
//小写转大写
for(int i=;i<len;i++){
if(str[i]>='a'&&str[i]<='z'){
str[i] = str[i]- ('a'-'A');
}
}
printf("%s",str); return ;
}

四、二维数组

1)实例:

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

1

1  1

1  2  1

1  3  3  1

1  4  6  4  1

1  5  10 10 5 1

实现代码:

  int main(){
int a[][];
for(int i=;i<;i++){
for(int j=;j<=i;j++){
if(j==||i==j)
a[i][j]=;
else
a[i][j]=a[i-][j]+a[i-][j-];
}
} for(int i=;i<;i++){
for(int j=;j<=i;j++){
printf("%5d",a[i][j]);
}
printf("\n");
}
return ;
}

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

实现代码:

 int main(){
int a=,b=;
a=a+b;
b=a-b;
a=a-b;
printf("a=%d;b=%d",a,b); return ;
}

iOS阶段学习第六天笔记(数组)的更多相关文章

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

                                                                                                  iOS学习( ...

  2. iOS阶段学习第一天笔记(Mac终端的操作)

    前言部分 原本从事的是.NET开发,一直在要不要转iOS 中犹豫徘徊,经过复杂的内心挣扎终于鼓起勇气辞职脱产学习iOS;希望通过四个月的 学习后能够拿到理想的薪资.以下是学习过程中的学习笔记,为了方便 ...

  3. iOS阶段学习第15天笔记(NSArray与NSMutableArray 数组)

    iOS学习(OC语言)知识点整理 一.OC中的数组 1)数组:也是一个对象,数组中存放的是对象的地址,可以存放任意类型对象的地址,只能是对象不能是具体的数值,数组是有序的,      可以存放重复的元 ...

  4. iOS阶段学习第四天笔记(循环)

    iOS学习(C语言)知识点整理笔记 一.分支结构 1.分支结构分为单分支 即:if( ){ } ;多分支 即:if( ){ }else{ }  两种 2.单分支 if表达式成立则执行{ }里的语句:双 ...

  5. iOS阶段学习第三天笔记(运算符)

    iOS学习(C语言)知识点整理笔记 1.运算符 一.算术运算符 1)表达式由变量.常量.运算符构成,有确定的类型和值 2)算术运算符包括: +(加),-(减),*(乘),/(除),%(模) 3)算术运 ...

  6. iOS 阶段学习第四天笔记(循环)

    iOS学习(C语言)知识点整理笔记 一.分支结构 1.分支结构分为单分支 即:if( ){ } ;多分支 即:if( ){ }else{ }  两种 2.单分支 if表达式成立则执行{ }里的语句:双 ...

  7. iOS 阶段学习第三天笔记(运算符)

    iOS学习(C语言)知识点整理笔记 1.运算符 一.算术运算符 1)表达式由变量.常量.运算符构成,有确定的类型和值 2)算术运算符包括: +(加),-(减),*(乘),/(除),%(模) 3)算术运 ...

  8. iOS阶段学习第30天笔记( UIViewController—Delegate(代理) )

    iOS学习(UI)知识点整理 一.UIViewController的介绍 1)概念:UIViewController 即视图控制器,用来管理和控制页面跳转的一个类 ,iOS里面采用了MVC的体系结构, ...

  9. iOS 阶段学习第23天笔记(XML数据格式介绍)

    iOS学习(OC语言)知识点整理 一.XML数据格式介绍 1)概念:xml是extensible markup language扩展的标记语言,一般用来表示.传输和存储数据 2)xml与json目前使 ...

随机推荐

  1. 让C#轻松实现读写锁分离--封装ReaderWriterLockSlim

    ReaderWriterLockSlim 类 表示用于管理资源访问的锁定状态,可实现多线程读取或进行独占式写入访问. 使用 ReaderWriterLockSlim 来保护由多个线程读取但每次只采用一 ...

  2. 微信授权步骤与详解 -- c#篇

    微信授权步骤与详解 -- c#篇 注:这里不涉及界面操作,只介绍代码操作. 1.基本原理如下: 从图上所知,第一步用户访问我们的网页,第二步我们后台跳转到微信授权页面,第三步用户点击授权,第四步微信重 ...

  3. Android开发学习之路-Service和Activity的通信

    在很多时候,Service都不仅仅需要在后台运行,还需要和Activity进行通信,或者接受Activity的指挥,如何来实现,来看代码. 定义一个服务 // 创建一个服务,然后在onBind()中返 ...

  4. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  5. [数据库连接池二]Java数据库连接池--C3P0和JDNI.

    前言:上一篇文章中讲了DBCP的用法以及实现原理, 这一篇再来说下C3P0和JDNI的用法. 1.1.C3P0数据源 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规 ...

  6. Atitit数据库层次架构表与知识点 attilax 总结

    Atitit数据库层次架构表与知识点 attilax 总结 第一阶段,大概理论(三五天 数据库的类型,网状,层次,树形数据库,kv数据库.Oodb Er模型   sql 并发控制与lock  Acid ...

  7. iOS-Objective-C内存管理

    内存管理: 栈区 [stack]:由编译器自动分配并释放,一般存放函数的参数值,局部变量等 堆区 [heap]:由程序员分配和释放,如果程序员不释放,程序结束时,可能会由操作系统回收 全局区(静态区) ...

  8. XML学习笔记2——DTD

    在上一篇笔记中,将文档类型分类时,曾经根据文档是否使用并遵守了DTD或Schema来区分为格式良好的XML和有效的XML,那么什么是DTD和Schema呢?DTD和Schema都是用来规范XML文档的 ...

  9. 快速入门系列--MVC--01概述

    虽然使用MVC已经不少年,相关技术的学习进行了多次,但是很多技术思路的理解其实都不够深入.其实就在MVC框架中有很多设计模式和设计思路的体现,例如DependencyResolver类就包含我们常见的 ...

  10. JS滚轮事件封装

    wheel(function(isTrue){ console.log(isTrue); }) function wheel(callback){ if(navigator.userAgent.ind ...