算法 笔记

目录一、交换二、冒泡排序三、选择排序四、顺序查找五、折半查找(二分查找)六、递归七、待更新一、交换1.使用指针作为函数参数思路:使用值进行交换,在main中调用时,只是交换了形参的值,并不会影响main中实参的值。因此使用指针作为函数参数,传入地址,这时 d f 有了实参a b 的地址,通过取地址运算符,实际是对 d f 中地址对应的变量 a b 的值进行交换#include <stdio.h>void swap(int d ,int f){ int c =
摘要由CSDN通过智能技术生成

一、交换

1.使用指针作为函数参数
思路:使用值进行交换,在main中调用时,只是交换了形参的值,并不会影响main中实参的值。因此使用指针作为函数参数,传入地址,这时 d f 有了实参a b 的地址,通过取地址运算符,实际是对 d f 中地址对应的变量 a b 的值进行交换

#include <stdio.h>

void swap(int d ,int f)
{
   
    int c = 0;
    c = d;
    d = f;
    f = c;
}

void swap_p(int* d,int* f)
{
   
    int c = 0;
    c = *d;
    *d = *f;
    *f = c;
}

int main()
{
   
    int a ,b;
    a = 1;
    b = 10;

    swap(a,b);
    printf("%d %d\n",a ,b); //此时不会交换

    swap_p(&a ,&b); //通过指针传入地址完成交换
    printf("%d %d\n",a ,b);

    return 0;
}

疑问:不使用取地址运算符,定义int* c = NULL ,然后只对地址进行交换,为什么不能达到交换值的目的?

2.引用做参数的交换

#include <iostream>
using namespace std;

void exchange(int& c,int& f)
{
   
    int i;
    i = c;
    c = f;
    f = i;
}

int main()
{
   
    int a = 1;
    int b = 10;

    exchange(a,b);

    cout << a << "\n" << b << endl;

    return 0;
}

3.使用宏

#include <stdio.h>
#define swap_x(x ,y ,t) ((t) = (x) ,(x) = (y) ,(y) = (t))

int main()
{
   
    int a ,b ,c;
    a = 1;
    b = 10;
    c = 0;

    swap_x(a,b,c);
    printf("%d %d\n",a ,b);
    return 0;
}

二、冒泡排序

思路:从左向右遍历数组,比较相邻两个数,如果左边大于右边,则进行交换

假设有以下6个数:5 9 7 6 3 2

交换过程如下:

第一次:5 7 6 3 2 9
第二次:5 6 3 2 7 9
第三次:5 3 2 6 7 9
第四次:3 2 5 6 7 9
第五次:2 3 5 6 7 9

#include <stdio.h>

void BS(int* a,int n)
{
   
    int i,j,t;
    for(i = 0 ; i < n-1 ; i++) //控制比较次数
    {
   
        for(j = 0 ; j < n-i-1; j++) // 比较,外循环增加一次,内循环减少一次
        {
   
            if (a[j] > a[j+1])
            {
   
                t = a[j];
                a[j] = a[j+1];
                a
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值