指针相减运算——C语言指针


#include
int main()
{

    int* p = (int*)-1;
    int* p1 = (int*)4;
    if (p > p1)
    {
        printf("p>p1\n");
    }
    else
    {
        printf("p);
    }

    printf("%d", p1 - p);
    return 0;
}

//结果是:1

对不是指向同一个“对象(内存空间)”的指针进行加减运算,其实并没有任何意义,其结果由实现决定。
ptrdiff_t这个专门进行指针计算的数据类型。
把一个毫不相关的值强制转成指针类型,与一个指针指向这个值的地址是不同的!

说明这里这两个整数分配的空间是相邻的int块,所以差值1表示偏差1个int类型空间。你试试printf("%d",(char * )p1 - (char * )p); 输出就不是1了

  • 你可以参考下这个问题的回答, 看看是否对你有帮助, 链接: https://ask.csdn.net/questions/7416773
  • 这篇博客也不错, 你可以看下一文解决数据结构——栈(C语言实现)
  • 你还可以看下leetcode参考手册中的 c语言-指针
  • 除此之外, 这篇博客: C语言--两数之和中的 两数之和 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标.

    你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素.

    示例:

    给定 nums = [2, 7, 11, 15], target = 9
    因为 nums[0] + nums[1] = 2 + 7 = 9
    所以返回 [0, 1]
    
    int* twoSum(int* nums, int numsSize, int target, int* returnSize){
       int i, j;
    int a, b;
    int* array = (int*)malloc(2 * sizeof(int));
    for (i = 0; i < numsSize; i++) {
    a = target - nums[i];
    //nums[i] = 0;
    for (j = 0; j < numsSize; j++) {
    if (nums[j] == a && i != j) {
    array[0] = i;
    array[1] = j;
    }
    }
    }
    *returnSize = 2;
    return array; 
    }