第八章-预编译处理

/*
 * @Issue: 输入两个整数,求他们相除的余数,用带参的宏编程来实现
 * @Author: 一届书生
 * @LastEditTime : 2020-01-23 09:55:37
 */
#include<iostream>
#include<math.h>
using namespace std;

// 宏编程
// 求两个整数相除的余数
#define MOD(a,b) a%b
// 交换两个元素
#define swap(x,y) {int t;t=x;x=y;y=t;}
// 判断是否是字母
#define ISALPHA(c) ((c>='A'&&c<'Z')||(c>'a'&&c<'z')?1:0)
// 判断整数n能否被x整除
#define DIV(n,x) ((n%x)==0?1:0)
// 计算三角形面积
#define S(a,b,c) ((a+b+c)/2)
#define AREA(a,b,c) sqrt(S(a,b,c)*(S(a,b,c)-a)*(S(a,b,c)-b)*(S(a,b,c)-c))

int main(){
    int a,b;
    cout<<"请输入两个整数a,b:"<<endl;
    cin>>a>>b;
 
    cout<<MOD(a,b)<<endl;
 
    cout<<"a:"<<a<<endl<<"b:"<<b<<endl;
    swap(a,b);
    cout<<"a:"<<a<<endl<<"b:"<<b<<endl;

    char c;
    cout<<"请输入一个字符来判断它是否是字母:"<<endl;
    cin>>c;
    if(ISALPHA(c)) cout<<c<<"是一个字母"<<endl;
    else cout<<c<<"不是一个字母"<<endl;

    int d;
    cout<<"请输入一个整数来判断它能否被3整除:"<<endl;
    cin>>d;
    if(DIV(d,3)) cout<<d<<"能被3整除"<<endl;
    else cout<<d<<"不能被3整除"<<endl;

    int e,f,g;
    cout<<"请输入三角形的三条边:"<<endl;
    cin>>e>>f>>g;
    cout<<AREA(e,f,g)<<endl;

    return 0;
}

  

猜你喜欢

转载自www.cnblogs.com/52dxer/p/12230233.html
今日推荐