C语言入门级教程 七

C语言入门级教程                  icesongqiang


2016.11.28

总结

  1. 关于宏定义,宏定义会在编译时在宏的所在位置按定义展开,也就是替换过程。如
    #define swap(a,b) {double temp=a;a=b;b=temp;} 那么就会在swap(a,b) 出现的地方由{double temp=a;a=b;b=temp;} 替换掉,注意此处的花括弧,它表示一个复合语句,复合语句内的变量是私有的。
  2. 最大最小以及逆序都比较简单,注意指针不要越界就可以。
  3. 在逆序函数中,使用随机数生成
  4. 关于 int a[N] 定义的问题, N不能是个变量, 非要用这种形式应该以const, enum, 或者define定义N, 一般我们用前两种方法, define没有类型检查,不是很安全。

求最大最小值

// 使用枚举类型, 规定返回最大值还是最小值
// icesongqiang

#include <stdio.h>
#include <stdlib.h>

enum flag_max_min{ getmin = 0, getmax = 1 }; // 定义返回最大还是最小的标志

/**返回一位数组中最大值和最小值
* @param *arr: 指针,数组的起始位置
* @param n : 数组长度
* @param flag : 0 for min , 1 for max
*/
float get_max_min(float *arr, int n, flag_max_min flag)
{
    int index = 0;        
    for (int i = 1; i < n; ++i){
        if (getmin == flag){                 // 返回最小值
            if (arr[i] < arr[index]) index = i;
        }
        else{                                // 返回最大值
            if (arr[i] > arr[index]) index = i;
        }
    }
    return arr[index];  
}

int main()
{
    float array[] = { 13, 4, 534, 34, 56, 67, 76, 564.4};
    printf("max:%f\n",get_max_min(array, 8, getmax));
    printf("min:%f\n", get_max_min(array, 8, getmin));
    system("pause");
    return 0;
}

宏定义交换

#include <stdio.h>
#include <stdlib.h>
#define swap(a,b) {double temp=a;a=b;b=temp;} // 宏定义交换两个数
int main()
{
    double a = 10.1, b = 27;
    printf("before swaping: a=%lf,b=%lf\n", a, b);
    int temp = 100;
    swap(a, b);    //不会改变外部temp的值
    printf("after swaping: a=%lf,b=%lf\n temp=%d\n", a, b, temp); // temp的值还是100
    system("pause");
    return 0;
}

逆序

// 模块化各个功能 
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
/**数据生成
*/
void generateData(int *arr, int n)
{
    srand((unsigned int)time(NULL));
    for (int i = 0; i < n; ++i){
        arr[i] = (int)rand() % 1000;   // 限定范围在1000之内   
    }
}
/**数组逆序存放
*/
void reverse(int *arr, int n)
{
    for (int i = 0; i < n >> 1; ++i){
        int tmp = *(arr + i);
        *(arr + i) = *(arr + n - 1 - i);
        *(arr + n - 1 - i) = tmp;
    }
}

/**数组打印
*/
void printArray(int *arr, int n)
{
    for (int i = 0; i < n; ++i){
        printf("%d\t", arr[i]);
    }
    printf("\n");
}

int main()
{
    const int N=10;
    int array[N];
    printf("generating data...\n");
    generateData(array, N);

    printf("before swaping:\n");
    printArray(array, N);

    reverse(array, N);

    printf("after swaping: \n");
    printArray(array, N);

    system("pause");
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值