[C语言]使用数组
-----------------------------------------------------------------------------
// main.c 例
// Created by weichen on 15/1/9.
// Copyright (c) 2015年 weichen. All rights reserved.
#include <stdio.h> int main() {
// 求输入的平均数 int x = ; //输入的数
double num = ; //总和(这个定义为double, 因为计算结果可能出现浮点数)
int count = ; //个数
double per; //平均数(结果也定义double) printf("请输入一些数:"); scanf("%d", &x); //大于0时执行累计;输入小于等于0的值 回车确定 来终止循环,并执行后面的代码
while(x > )
{
num += x;
count++;
scanf("%d", &x);
} if(count > )
{
per = num / count;
printf("%f \n", per);
} return ;
}
// main.c 例
// Created by weichen on 15/1/14.
// Copyright (c) 2015年 weichen. All rights reserved.
#include <stdio.h> int main() { //输入一个数,并输出平均值和大于平均值的数
//要点:需要存放输入的这些数 int x = ;
int n = ;
double total = ;
double per = ;
int number[]; //1. 定义数组 printf("请输入一些数:");
scanf("%d", &x); while(x != )
{
number[n] = x; //2. 数组元素赋值
total += x;
n++;
} if(n > )
{
per = total/n; printf("平均数为:%f\n", per); printf("大于平均数的数为:"); for(int i = ; i <= n; i++)
{
if(number[n] > per) //3. 使用数组元素
{
printf("%d\t", number[i]); //4. 遍历数组
}
}
} return ;
} 注:Xcode里编译后输入数字回车,number[n]=x 行报错 Thread1:EXC_BAD_ACCESS(code=2,address=0x7fff5fc00000),有人知道原因吗?
// main.c 例
// Created by weichen on 15/1/19
// Copyright (c) 2015年 weichen. All rights reserved.
#include <stdio.h> int main() {
//输入0-9范围内的数字,求输入每个输入的数字的次数
const int number = ;//1. 数组大小
int x;
int count[number]; //2. 定义数组
int i; for(i=; i<=number; i++)
{
count[i] = ; //3. 初始化数组
} printf("请输入:");
scanf("%d", &x); while(x != -)
{
if(x>= && x<=)
{
count[x]++; //4. 数组参与运算
}
scanf("%d", &x);
} for(i=; i <= number; i++)
{
printf("%d:%d\n", i, count[i]);
} return ;
}
// main.c 一维数组
// Created by weichen on 15/1/28.
// Copyright (c) 2015年 weichen. All rights reserved.
#include <stdio.h> int main() {
/* 一. 数组的集成初始化
int a[] = {1, 2, 6, 7, 9}; for ( int i = 0; i < 5; i++)
{
printf("%d\t", a[i]);
}
*/
/* 1. 声明一个长度12的数组,第一个元素赋值为1,其余为0
int a[12] = {1};
for ( int i = 0; i < 12; i++)
{
printf("%d\t", a[i]);
}
*/ /* 2. 不使用循环,初始化数组
int a[12] = {0};
*/
/* 二. 集成初始化时的定位
int a[12] = {[1]=2, 3, [4]=9};
用[x]在初始化数据时给出定位
没有定位的数据跟在前一个后面
其它位置的值补0
也可以不给出数组的大小,让编译器运算
适合初始化稀疏的数组 {
for(int i = 0; i < 12; i++) {
printf("%d\t", a[i]); //0 2 3 0 9 0 ....
}
}
*/ /* 三. 数组赋值 */
int a[] = {, };
int length = sizeof(a)/sizeof(a[]);
int b[length];
//1. 数组变量本身不能被赋值,如:int b[] = a;错误
//2. 要把一个数组的值交给另一个数组,必须使用遍历,如下:
for(int i = ; i < length; i++) {
b[i] = a[i];
}
{
for(int i = ; i < length; i++) {
printf("%d\t", a[i]); //0 2 3 0 9 0 ....
}
}
//遍历数组作用:
//3. 赋值、初始化、判断值是否存在,计数
//4. 离开循环后,i不能再作为下标访问数组元素 return ;
}
/**
* 思考题:查找某值是否存在数组中
* @weiChen
*/ #include <stdio.h> int main()
{
int a[] = {, , , , , }; int key; int length = sizeof(a)/sizeof(a[]); printf("请输入一个数:"); scanf("%d", &key); int location = search(key, a, length); if(location != -)
{
printf("key:%d存在于数组a[]中。\n", key);
}
else
{
printf("数组a[]中不存在key:%d。\n", key);
} return ;
} /**
* 函数:找出key在数组中的位置
* @param key 位置
* @param a 数组
* @param length 数组长度
* @return 存在则返回数组的位置,否则返回-1
*
* int search(int key, int a[]; int length);
*/ int search(int key, int a[], int length)
{
for(int i = ; i < length; i++)
{
if(a[i] == key)
{
return i;
break;
}
} return -;
}
// main.c 多维数组
// Created by weichen on 15/1/30.
// Copyright (c) 2015年 weichen. All rights reserved.
#include <stdio.h> int main(int argc, const char * argv[]) { //二维数组,三行五列矩阵
int a[][]; for(int i = ; i < ; i++) {
for(int j = ; j < ; j++) {
a[i][j] = i * j;
}
} //二维数组的初始化
int b[][] = {
{, , , , },
{, , , , },
}; //1.列数是必须给出的,行数可以由编译器来数。
//2.每一行一个{},逗号分隔
//3.最后的逗号可以存在,有古老的传统
//4.如果省略,表示补零
//5.也可以用定位(C99 ONLY) //int c[][3] = {{0}, {1}, {2}}; //三行三列,每列自动补零
//printf("%d", c[1][2]); int d[][] = {, , , , , , , , ,};//初始化为3列,自动分为三行
int i, j, k = ;
for(i = ; i < ; i++) {
printf("%d", d[k][i]);//循环输出d[2][i]
}
return ;
}
int a[][]; =>示意图 a[][], a[][], a[][], a[][]
a[][], a[][], a[][], a[][]
a[][], a[][], a[][], a[][]
17.2.23 备注 (数组值的输出):
由于数组是特殊的指针,即常量指针类型,那么 char arr[10] 可以 (char*)arr 取值;参考php内核中 ZVAL_STRING(z,s,duplicate) 的例子。
Link: http://www.cnblogs.com/farwish/p/4212336.html
[C语言]使用数组的更多相关文章
- 【算法】C语言实现数组的动态分配
C语言实现数组的动态分配 作者:白宁超 2016年10月27日20:13:13 摘要:数据结构和算法对于编程的意义不言而喻,具有指导意义的.无论从事算法优化方向研究,还是大数据处理,亦或者网站开发AP ...
- C语言一维数组、二维数组、结构体的初始化
C语言数组的初始化表示方法 一.C语言一维数组初始化: (1)在定义数组时对数组元素赋以初值.如: static int a[10]={0,1,2,3,4,5,6,7,8,9}; 经过上面的定义和初始 ...
- go语言的 数组、slice、map使用(转)
golang群 点击加入 go语言的 数组.slice.map使用, 由于网上有很好的说明, 不需要再写了,请看这几篇: Go语言中的 Array, Slice和 Map 深入学习golang五篇,以 ...
- go语言 类型:数组
在go语言中数组array是一组特定长度的有序的元素集合. go的数组类型由两部分组成——类型和长度,二者缺一不可.数组本来就是一块存储相同类型元素的连续内存空间,因此决定一个数组的类型,必然需要决定 ...
- C语言基础--数组及相关
概念: 一堆相同类型的数据的有序集合 格式: 元素类型 数组名称[ 元素个数 ] 定义数组: // 定义了一个名称叫做scores的数组, 数组中可以存放3个int类型的数据 ]; // 只要定义一 ...
- 学习C语言的数组
C语言的数组 数组声明的实例:int num[3];只要记下这个模板就好. 不建议使用变量定义数组,如果使用了变量定义数组,作为数组的元素的个数,不初始化的情况下是随机值,如果初始化会直接报错 注意: ...
- 对于C语言中数组名是指针的理解
我们都知道,c语言中数组名是一个指针,比如下面这段代码 #include<iostream>using namespace std;int main(){ int a[4]={1,2,3, ...
- c语言中数组相关问题
c语言中数组相关问题: 1.数组基本定义: 相同数据类型的元素按一定顺序排列的集合,就是把有限个类型相同的变量用一个名字命名,然后用编号区分他们的变量的集合,这个名字称为数组名,编号称为下标.组成数组 ...
- 线性表之顺序存储结构(C语言动态数组实现)
线性表的定义:N个数据元素的有限序列 线性表从存储结构上分为:顺序存储结构(数组)和 链式存储结构(链表) 顺序存储结构:是用一段连续的内存空间存储表中的数据 L=(a1,a2,a3....an) 链 ...
- C语言入门(16)——C语言的数组
和结构体类似,数组也是一种复合数据类型,它由一系列相同类型的元素组成.C语言支持一维数组和多维数组.如果一个数组的所有元素都不是数组,那么该数组称为一维数组. 一维数组的定义方式 在C语言中使用数组必 ...
随机推荐
- linux下的网络通信设置:openssh、PuTTY、tightVNC
OpenSSH的安装: windows上安装PuTTY: PuZZY上传文件到linux: 1.在window下的cmd中cd到PuZZY所在的文件夹下 2.使用pscp命令上传文件 3.使用psc ...
- 在线学习和在线凸优化(online learning and online convex optimization)—凸化方法4
一些在线预测问题可以转化到在线凸优化框架中.下面介绍两种凸化技术: 一些在线预测问题似乎不适合在线凸优化框架.例如,在线分类问题中,预测域(predictions domain)或损失函数不是凸的.我 ...
- package.json-nodeJs
package.json文件描述了一个NPM包的所有相关信息,包括作者.简介.包依赖.构建等信息.格式必须是严格的JSON格式. 通常我们在创建一个NPM程序时,可以使用npm init命令,通过交互 ...
- mysql中min和max查询优化
mysql max() 函数的需扫描where条件过滤后的所有行: 在测试环境中重现: 测试版本:Server version: 5.1.58-log MySQL Community ...
- CS229 2.深入梯度下降(Gradient Descent)算法
1 问题的引出 对于上篇中讲到的线性回归,先化一个为一个特征θ1,θ0为偏置项,最后列出的误差函数如下图所示: 手动求解 目标是优化J(θ1),得到其最小化,下图中的×为y(i),下面给出TrainS ...
- build.gradle 中compileSdkVersion,minSdkVersion,targetSdkVersion,buildToolsVersion的意思
compileSdkVersion: 编译版本:compileSdkVersion告诉gradle使用哪个版本AndroidSDK编译你的应用: minSdkVersion: 最低SDK版本:他代表的 ...
- restframwork框架
一 APIView: class PublishView(APIView): def get(self,request): publish_list=Publish.objects.all() ret ...
- Dom4j解析、生成Xml
1以下代码未Xml的解析和生成代码 <?xml version="1.0" encoding="UTF-8"?> <users> < ...
- [转] 高频 mos 选择需要考虑相关资料
节选自 http://www.dianyuan.com/bbs/987183.html [草根大侠]贴 关于MOS管导通内阻和米勒电容(Qgd)差异对效率的影响 http://www.epc.com. ...
- 代码:jquery自定义插件 demo
jquery自定义插件 demo 2016-1-13 只是一个简易的示例 <script type="text/javascript" src="http://cd ...