1.一维数组与指针
  
    形如:int型 数组 a[10]  
              1)&a[0]  地址常量;地址类型:int *型   ; 存储数组a的首地址
              2) a        地址常量;地址类型:int *型   ; 存储数组a的首地址        即  a与 &a[0]等价 
   形如:指向一维数组的指针变量 
              如有定义: int a[10],*p;
              ①p = &a[6];     //表示将a[6]的地址赋给指针变量p
              ②p = a
                 p = &a[0]       //均表示将数组a的地址(or a[0]的地址)赋给指针变量p
   形如:指针可进行的运算
               预先定义:指针变量p,数组a[10],正整数n;
                   1)指针 ± 数值  【实际值:p±n*size |  其中size指p的基类型所占用的存储字节数】
                         p + n :指向a[i]后面的第n个元素;
                         p - n  :  指向a[i]前面的第n个元素;
                        
                         ※若定义:*p = a;
                             则: 
                                 *(a+i)   或者   a[i]
                                 *(p+i)    或者  p[i]         //四者意义:访问数组a中的第i个元素 
                            本质与区别:
                                               1.p与a数据类型均为int *型;
                                               2.p是指针变量;a是指针常量(指向不可改变)
                   2)指针 -指针 
                     前提:指向相同类型的指针变量可以相减
                      结果:两指针所指向的地址之间数据的个数(单位:数据类型,并非字节数)
                      Eg:
                           int *px,*py,n,a[5];
                           px = &a[1]; 
                           py = &a[4]; 
                           n = py - px;  //结果:n = 3
                           n = px - py;  //结果: n = -3 
        3)指针的比较运算(<,>,==,!=,<=,>=)
            实质:比较两个地址值的大小。
                          结果:1 or 0
                         Eg:px == py  //两地址相同?0:1
                              px < py    //px<py?0:1
                              px==NULL //px为空指针?0:1
                              即  真为0;假为1 
--------------------------------------------------------------------------------------------------------
元素的地址:                                                         元素的值:
        a+i   数组名法                                                        *(a+i)      数组名法                           
        p+i   指针法                                                            *(p+i)      指针法
        &a[i] 下标法                                                             a[i]        下标法  
        &p[i]下标法                                                              p[i]        下标法  
---------------------------------------------------------------------------------------------------------
典型例子1:分别求数组前十个元素和后十个元素之和
#include<iostream>
int fsum(int *array,int n) {     //通用的求和函数
     int  i,s = 0;
     for(i = 0;i<n;i++)
          s += array[i]
    return (s);

void main(void){
   int a[15] = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
   int shead ,stail;
   shead = fsum(&a[0],10);   //or fsum(a,10)
   stail = fsum(&a[5],10) ;     //or fsum(a+5,10) 
}            
---------------------------------------------------------------------------------------------------------
典型例子2:比较两字符串的大小:
  int my_strcmp(char *s,char *p){
     for(;*s==*p;s++;p++)
             if(*s=='\0')  reutrn (0);  //如果都比较到最后一个字符了,那么二者相等
     return (*s-*t)>0?1:-1;     

[C++]指针和指向数组的指针[一维数组与指针]的更多相关文章

  1. PHP开发小技巧③—实现多维数组转化为一维数组

    在平常的项目开发中我们多会用到让多维数组转化为一维数组的情况,但是很多Programmer不会将其进行转化,也有些没有想到很好的算法然后经过乱起八糟的运算方式将其勉强转化好,但是所写的程序代码冗余非常 ...

  2. 二维数组转化为一维数组 contact 与apply 的结合

    将多维数组(尤其是二维数组)转化为一维数组是业务开发中的常用逻辑,除了使用朴素的循环转换以外,我们还可以利用Javascript的语言特性实现更为简洁优雅的转换.本文将从朴素的循环转换开始,逐一介绍三 ...

  3. [Swift]多维数组的表示和存储:N维数组映射到一维数组(一一对应)!

    数组:有序的元素序列. 若将有限个类型相同的变量的集合命名,那么这个名称为数组名.组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量.用于区分数组的各个元素的数字编号称为下标.数组 ...

  4. Python数组操作将一维数组变成二维数组

    一.问题 我们在进行数组操作的时候会遇到将一个低维的数组变成一个高维的素数组 二.解决 第一种方法基本思路就是将低维数组进行等长的循环,在第一次为零的情况下,需要添加一个[]数组,原因是将它的基本框架 ...

  5. 题目要求:传入数组 内容为[['lisi','男','27'],['wangwu','男',18],['zhaoliu','男','30']],将此二维数组转化为一维数组,创建自定义函数完成

    //自定义函数 function getOne($arr){ $str = ''; //定义空的字符串,用来接收值 foreach ($arr as $key=>$value){ //循环遍历数 ...

  6. 将二维数组转换成一维数组(基于reduce)

    reduce:不改变原数组,返回一个新的数组.就是遍历数组元素,从头开始,依次往下,第一个参数是上一次的返回值,第二个参数是下一个数组元素,首次的时候第一个和第二个参数分别是 array[0],  a ...

  7. php数组去重(一维数组)

    <?php $arr = ['1', '1', 'PHP', 'PHP', 2, 3]; print_r($arr); echo "<br>"; print_r( ...

  8. php二维数组转成一维数组

    $arr是需要转换的数组集合 array_reduce($arr, 'array_merge', array());

  9. python算法:嵌套数组转变成一维数组

    比如,输入是:[2, 1, [3, [4, 5], 6], 7, [8]] 则,输出是:[2, 1, 3, 4, 5, 6, 7, 8] def list_flatten(l, a=None): a ...

  10. C++入门经典-例6.10-将多维数组转换成一维数组

    1:代码如下: // 6.10.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> usin ...

随机推荐

  1. Delphi编码规范

    以下是在之前的公司与别人共同参与制定的Delphi开发规范(5年前了,那时用的还是Delphi7,部分规则可能有些过时,但不整理了,觉得有用的人,自己整理成适合自己的开发规范吧), 目    录一.序 ...

  2. 配合es5.8的使用,升级sb版本到2.X,遇到一个问题

    问题:Failed to bind properties under 'spring.redis.jedis.pool.max-wait' to java.time.Duration: Propert ...

  3. Java基础总结(一)

    1:程序执行是有顺序的,如果没有流程控制语句,执行顺序是从上到下, 2:对象没有引用指向他的时候,jvm虚拟机就会在合适的时候去清理内存垃圾 3:对象的引用就相当于方向盘,操作对象 4:java8大基 ...

  4. BZOJ1127 POI2008KUP(悬线法)

    首先显然地,如果某个格子的权值超过2k,其一定不在答案之中:如果在[k,2k]中,其自身就可以作为答案.那么现在我们只需要考虑所选权值都小于k的情况. 可以发现一个结论:若存在一个权值都小于k的矩阵其 ...

  5. 睡前小dp-poj3254-状压dp入门

    http://poj.org/problem?id=3254 从这里学的 http://blog.csdn.net/accry/article/details/6607703 状压dp的入门题.一片N ...

  6. bzoj 3224: Tyvj 1728 普通平衡树 && loj 104 普通平衡树 (splay树)

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=3224 思路: splay树模板题: 推荐博客:https://blog.csdn.ne ...

  7. hdu 6319 Problem A. Ascending Rating (2018 Multi-University Training Contest 3 A)

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=6319 思路: 单调队列倒着维护,队列里面剩下的值的数量就是这一段区间的count值,如样例第一个区间:3 ...

  8. 今天一天课,随便写点吧/xk

    知道的越多,不知道的也就越多. 最近想学很多很多东西,但是发现没有一个计划,也没有那么多时间精力,都是想到哪学到哪,有的就是学了一半就放下了,又去学新的,感觉需要规划一下学习路线,时间什么的 推荐一个 ...

  9. luogu3295 萌萌哒 (并查集+ST表)

    如果给相同的位置连边,最后联通块数是n,最后答案就是$9*10^{n-1}$ 但直接连边是$O(n^2)$的 所以事先处理出一个ST表,每次O(1)地给那个ST表连边 最后再一点一点下放,就是把在这层 ...

  10. python 线程间事件通知

    这是线程间最简单的通信机制:一个线程发送事件,其他线程等待事件事件机制使用一个内部的标志,使用set方法进行使能为True,使用clear清除为falsewait方法将会阻塞当前线程知道标记为True ...