|  | 
 
| 
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  复制代码#include <stdio.h>
int *sever(int *, int, int);
int *sever(int *p, int len, int n){//n是查询数字
        int *q = p+n/2;
        //记录一半位置的指针
        if (n < *q){//待查询值偏小
                return sever(p, len/2, n);
        }
        else if(n > *q){
                return sever(q, len/2, n);
        }
        else {
                return (*q == n)?q:p;
        }
}
int main()
{
        int array[10] = {1,2,3,4,5,6,7,8,9,10};
        //这里我想写成下面这样就可以少定义一个指针
        //int (*q)[10] = {1,2,3,4,5,6,7,8,9,10};
        //对于这个指针我的理解是:q是一个指针、指向一个含有十个int型元素的数组,进行一层解引用跨度应该是一个int吧
        //实验代码 -- 比如我想访问数字2
        //printf("%d ", *q + 1);
        //输出结果是5
        //printf("%d ", *q + 2);
        //输出结果是9 
        //综上q指针的一层解引用跨度是4,为什么呢?
        int *p = array;
        int i = 5;
        
        printf("%d", *sever(p, 10, i));
        
        return 0;
}
 问题已经在代码中间有问题的位置,请求大佬能帮我解答一下这个问题
  ,求求了   
复制代码//这里我想写成下面这样就可以少定义一个指针
//int (*q)[10] = {1,2,3,4,5,6,7,8,9,10};
这种写法第一次见,我试了一下,应该写成这样
int (*q)[10] = &(int [10]){1,2,3,4,5,6,7,8,9,10};
这样写没问题的
   0x0000000100401080 <+0>:     push   %rbp
   0x0000000100401081 <+1>:     mov    %rsp,%rbp
   0x0000000100401084 <+4>:     sub    $0x50,%rsp
   0x0000000100401088 <+8>:     callq  0x100401100 <__main>
   0x000000010040108d <+13>:    movl   $0x1,-0x30(%rbp)
   0x0000000100401094 <+20>:    movl   $0x2,-0x2c(%rbp)
   0x000000010040109b <+27>:    movl   $0x3,-0x28(%rbp)
   0x00000001004010a2 <+34>:    movl   $0x4,-0x24(%rbp)
   0x00000001004010a9 <+41>:    movl   $0x5,-0x20(%rbp)
   0x00000001004010b0 <+48>:    movl   $0x6,-0x1c(%rbp)
   0x00000001004010b7 <+55>:    movl   $0x7,-0x18(%rbp)
   0x00000001004010be <+62>:    movl   $0x8,-0x14(%rbp)
   0x00000001004010c5 <+69>:    movl   $0x9,-0x10(%rbp)
   0x00000001004010cc <+76>:    movl   $0xa,-0xc(%rbp)
   0x00000001004010d3 <+83>:    lea    -0x30(%rbp),%rax
   0x00000001004010d7 <+87>:    mov    %rax,-0x8(%rbp)
=> 0x00000001004010db <+91>:    mov    $0x0,%eax
   0x00000001004010e0 <+96>:    add    $0x50,%rsp
   0x00000001004010e4 <+100>:   pop    %rbp
   0x00000001004010e5 <+101>:   retq
int *p = array;
p 指向数组
*p 就是数组
*p 和 array 是等价的
*p + 1 就等于 array + 1
数组名是数组第 0 个元素的地址
array + 1 就是 &array[0] + 1
一个 int 类型的地址加 1,什么概念?
int a = 123;
int *p = &a;
p + 1 是什么意思?
 | 
 |