亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? math.cpp

?? 卡耐基SSD6全部選擇題和練習題解決方法。
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/* math -- instructions for Machine */

#include "flincl.h"
#include "math.h"

#define min(a, b) (a < b ? a : b)
#define max(a, b) (a > b ? a : b)

/* get_long -- get an integer value from FVal,
 *  assumes that p is not NULL
 */
        

void Machine::op_truncate()
{
    FUnion p = read_tos();
    long pval;
    if (p.node) {
        if (p.node->has_tag(TAG_LONG)) {
            // do nothing
        } else if (p.node->has_tag(TAG_DOUBLE)) {
            pval = (long) p.fdouble->get_double();
            pop();
            push(FLong::create(pval, this));
        } else not_a_number();
    } else not_a_number();
}


void Machine::op_float()
{
    FUnion p = read_tos();
    int64 pval;
    if (p.node) {
        if (p.flong->test_long(&pval)) {
            replace(FDouble::create((double) pval, this));
        } else if (p.node->has_tag(TAG_DOUBLE)) {
            // do nothing
        } else not_a_number();
    } else not_a_number();
}


void Machine::op_round()
{
    FUnion p = read_tos();
    int64 pval;
    if (p.node) {
        if (p.node->has_tag(TAG_LONG)) {
            // do nothing
        } else if (p.node->has_tag(TAG_DOUBLE)) {
            pval = (long) (p.fdouble->get_double() + 0.5);
            replace(FLong::create(pval, this));
        } else not_a_number();
    } else not_a_number();
}


void Machine::op_inc()
{
    FUnion p = read_tos();
	FVal newp;
    int64 pval;
    if (p.node) {
        if (p.flong->test_long(&pval)) {
            newp = FLong::create(pval + 1, this);
        } else if (p.node->has_tag(TAG_DOUBLE)) {
            newp = FDouble::create(p.fdouble->get_double() + 1.0, this);
        } else {
            newp = NULL;
            not_a_number();
        }
    }
    replace(newp);
}


void Machine::op_dec()
{
    FUnion p = read_tos();
	FVal newp = NULL;
    int64 pval;
    if (p.node) {
        if (p.flong->test_long(&pval)) {
            newp = FLong::create(pval - 1, this);
        } else if (p.node->has_tag(TAG_DOUBLE)) {
            newp = FDouble::create(p.fdouble->get_double() - 1.0, this);
        } else {
            not_a_number();
        }
    }
    replace(newp);
}

#define abs64(x) ((x) < 0 ? -(x) : x)

void Machine::op_abs()
{
    FUnion p = read_tos();
	FVal newp = NULL;
    int64 pval;
    if (p.node) {
        if (p.flong->test_long(&pval)) {
            newp = FLong::create(abs64(pval), this);
        } else if (p.node->has_tag(TAG_DOUBLE)) {
			double d = p.fdouble->get_double();
			if (d < 0) d = -d;
            newp = FDouble::create(d, this);
        } else {
            not_a_number();
        }
    }
    replace(newp);
}


void Machine::op_sin()
{
    FDouble_ptr p = read_tos().fdouble;
	double d;
    if (p->test_double(&d)) {
        replace(FDouble::create(sin(d), this));
    } else not_a_float();
}


void Machine::op_cos()
{
    FDouble_ptr p = read_tos().fdouble;
	double d;
    if (p->test_double(&d)) {
        replace(FDouble::create(cos(d), this));
    } else not_a_float();
}


void Machine::op_tan()
{
    FDouble_ptr p = read_tos().fdouble;
	double d;
    if (p->test_double(&d)) {
        replace(FDouble::create(tan(d), this));
    } else not_a_float();
}


void Machine::op_exp()
{
    FDouble_ptr p = read_tos().fdouble;
	double d;
    if (p->test_double(&d)) {
        replace(FDouble::create(exp(d), this));
    } else not_a_float();
}


void Machine::op_sqrt()
{
    FDouble_ptr p = read_tos().fdouble;
	double d;
    if (p->test_double(&d)) {
        replace(FDouble::create(sqrt(d), this));
    } else not_a_float();
}


void Machine::op_lognot()
{
    FLong_ptr p = read_tos().flong;
	int64 i;
    if (p->test_long(&i)) {
        replace(FLong::create(~i, this));
    } else not_an_integer();
}


void Machine::op_minus()
{
    FUnion p = read_tos();
	FVal newp;
    int64 i;
	double d;
    if (p.node) {
        if (p.flong->test_long(&i)) {
            newp = FLong::create(-i, this);
        } else if (p.fdouble->test_double(&d)) {
            newp = FDouble::create(-d, this);
        } else {
            newp = NULL;
            not_a_number();
        }
    }
    replace(newp);
}


void Machine::op_bool2int()
{
	Symbol_ptr p = read_tos().symbol;
	if (p == NULL) replace(FLong::create(0, this));
	else if (p == s_true) replace(FLong::create(1, this));
	else not_a_boolean();
}


void Machine::op_int2bool()
{
    FLong_ptr p = read_tos().flong;
	int64 i;
    if (p->test_long(&i)) {
        replace(i ? s_true : NULL);
    } else not_an_integer();
}


/* BINARY OPERATORS */


void Machine::op_add()
{
    FUnion p1 = read_next_tos();
    FUnion p2 = read_tos();
    int64 p1val, p2val;
    FVal res = NULL;
    if (p1.node && p2.node) {
        if (p1.flong->test_long(&p1val)) {
            if (p2.flong->test_long(&p2val)) {
                res = FLong::create(p1val + p2val, this);
            } else if (p2.node->has_tag(TAG_DOUBLE)) {
                res = FDouble::create(p1val + p2.fdouble->get_double(), this);
            } else not_a_number();
        } else if (p1.node->has_tag(TAG_DOUBLE)) {
            if (p2.flong->test_long(&p2val)) {
                res = FDouble::create(p1.fdouble->get_double() + p2val, this);
            } else if (p2.node->has_tag(TAG_DOUBLE)) {
                res = FDouble::create(p1.fdouble->get_double() + p2.fdouble->get_double(), this);
            } else not_a_number();
        } else if (p1.node->has_tag(TAG_ARRAY) && p2.node->has_tag(TAG_ARRAY)) {
            res = p1.array->concatenate(p2.array, this);
        } else if (p1.node->has_tag(TAG_STRING) && p2.node->has_tag(TAG_STRING)) {
            res = p1.fstring->concatenate(p2.fstring, this);
        } else not_a_number();
    } else not_a_number();
    pop();
    replace(res);
}


void Machine::op_sub()
{
    FUnion p1 = read_next_tos();
    FUnion p2 = read_tos();
    int64 p1val, p2val;
    FVal res = NULL;
    if (p1.node && p2.node) {
        if (p1.flong->test_long(&p1val)) {
            if (p2.flong->test_long(&p2val)) {
                res = FLong::create(p1val - p2val, this);
            } else if (p2.node->has_tag(TAG_DOUBLE)) {
                res = FDouble::create(p1val - p2.fdouble->get_double(), this);
            } else not_a_number();
        } else if (p1.node->has_tag(TAG_DOUBLE)) {
            if (p2.flong->test_long(&p2val)) {
                res = FDouble::create(p1.fdouble->get_double() - p2val, this);
            } else if (p2.node->has_tag(TAG_DOUBLE)) {
                res = FDouble::create(p1.fdouble->get_double() - 
                                          p2.fdouble->get_double(), this);
            } else not_a_number();
        } else not_a_number();
    } else not_a_number();
    pop();
    replace(res);
}


void Machine::op_mul()
{
    FUnion p1 = read_next_tos();
    FUnion p2 = read_tos();
    int64 p1val, p2val;
    FVal res = NULL;
    if (p1.node && p2.node) {
        if (p1.flong->test_long(&p1val)) {
            if (p2.flong->test_long(&p2val)) {
                res = FLong::create(p1val * p2val, this);
            } else if (p2.node->has_tag(TAG_DOUBLE)) {
                res = FDouble::create(p1val * p2.fdouble->get_double(), this);
            } else not_a_number();
        } else if (p1.node->has_tag(TAG_DOUBLE)) {
            if (p2.flong->test_long(&p2val)) {
                res = FDouble::create(p1.fdouble->get_double() * p2val, this);
            } else if (p2.node->has_tag(TAG_DOUBLE)) {
                res = FDouble::create(p1.fdouble->get_double() * 
                                          p2.fdouble->get_double(), this);
            } else not_a_number();
        } else not_a_number();
    } else not_a_number();
    pop();
    replace(res);
}


void Machine::op_power()
{
    FUnion p1 = read_next_tos();
    FUnion p2 = read_tos();
    int64 l;
    double d1, d2;
    FVal res = NULL;
    if (p1.node && p2.node) {
        if (p1.flong->test_long(&l)) {
            d1 = (double) l;
        } else if (p1.node->has_tag(TAG_DOUBLE)) {
            d1 = p1.fdouble->get_double();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕亚洲欧美在线不卡| 色婷婷综合中文久久一本| 国产精品无圣光一区二区| 欧美视频在线观看一区二区| 免费看欧美女人艹b| 亚洲青青青在线视频| 日韩女优毛片在线| 99国产精品99久久久久久| 日本中文字幕不卡| 一二三四社区欧美黄| 国产精品国产三级国产专播品爱网| 91精品国产91热久久久做人人| 丁香婷婷综合色啪| 国产久卡久卡久卡久卡视频精品| 亚洲成人动漫一区| 亚洲午夜精品久久久久久久久| 久久青草国产手机看片福利盒子| 欧美精三区欧美精三区| 亚洲日本丝袜连裤袜办公室| 欧美视频一区二| 色婷婷综合久久久久中文一区二区| 成人免费va视频| 99久久精品免费| 99国产精品久久久| 91丨porny丨国产| 91香蕉视频污| 欧美性生活久久| 欧美日韩精品二区第二页| 欧美乱妇一区二区三区不卡视频| 色婷婷综合久久久久中文一区二区| 色国产综合视频| 欧美日韩黄视频| 日韩免费看的电影| 欧美精品一区二区久久久| 久久蜜桃av一区精品变态类天堂| 久久久久久亚洲综合影院红桃| 国产日韩三级在线| 一个色综合网站| 日本不卡免费在线视频| 成人听书哪个软件好| 在线免费观看成人短视频| 欧美日韩一二三区| 久久久不卡影院| 天天色天天爱天天射综合| 成人蜜臀av电影| 911精品国产一区二区在线| 国产视频911| 午夜伦欧美伦电影理论片| 国产激情一区二区三区四区| 日本高清不卡一区| 久久久久久99久久久精品网站| 136国产福利精品导航| 美女看a上一区| 欧美日韩综合不卡| 国产精品第四页| 国产在线一区二区| 欧美肥胖老妇做爰| 亚洲欧美另类小说| 成人av免费在线播放| 精品国产一区二区三区忘忧草| 亚洲成av人片www| 色老汉一区二区三区| 国产精品看片你懂得| 国产伦精品一区二区三区免费| 777亚洲妇女| 亚洲福利电影网| 欧美亚洲一区二区三区四区| 亚洲三级在线免费| 成人国产亚洲欧美成人综合网 | 欧美一卡在线观看| 亚洲午夜久久久| 一本久久综合亚洲鲁鲁五月天| 久久精品一区四区| 懂色av中文一区二区三区| 欧美一级高清片| 日韩中文字幕一区二区三区| 欧美久久久久中文字幕| 婷婷综合另类小说色区| 欧美一级搡bbbb搡bbbb| 青青草97国产精品免费观看无弹窗版| 欧美日韩夫妻久久| 热久久国产精品| 日本一区二区动态图| 国产精品国产成人国产三级| 亚洲成a人片在线观看中文| 在线观看日韩高清av| 香蕉av福利精品导航| 欧美人体做爰大胆视频| 丝袜亚洲另类欧美| 久久综合丝袜日本网| bt欧美亚洲午夜电影天堂| 亚洲狠狠爱一区二区三区| 7777精品伊人久久久大香线蕉的| 国产自产2019最新不卡| 亚洲欧美在线aaa| 欧美一级片免费看| 99久久久国产精品免费蜜臀| 午夜精品久久久久久久久| 日韩欧美国产三级电影视频| 丁香另类激情小说| 日本免费在线视频不卡一不卡二| 久久精品无码一区二区三区| 欧美在线播放高清精品| 国产美女视频一区| 美腿丝袜亚洲三区| 一卡二卡三卡日韩欧美| 国产精品免费视频网站| 日韩一区二区三区四区| 色国产综合视频| 色综合久久综合网欧美综合网| 国产乱码精品一区二区三区忘忧草 | 久久综合九色综合久久久精品综合| 91麻豆免费在线观看| 成人午夜电影网站| 国产成人免费在线观看不卡| 日韩电影一区二区三区四区| 亚洲一区av在线| 国产精品成人免费在线| 26uuu国产电影一区二区| 欧美一区二区私人影院日本| 欧美性大战久久久久久久| 97aⅴ精品视频一二三区| 成人精品免费视频| 盗摄精品av一区二区三区| 国产精品一区二区久久不卡| 激情综合网天天干| 国产专区欧美精品| 国产成人免费视| 波多野结衣精品在线| 不卡的av中国片| 日本黄色一区二区| 欧美日韩一区二区在线视频| 欧美亚洲图片小说| 欧美大白屁股肥臀xxxxxx| 亚洲精品一区二区三区香蕉| 国产欧美久久久精品影院| 国产视频不卡一区| 亚洲香肠在线观看| 久久精品国产免费| eeuss鲁片一区二区三区在线看| 日本韩国精品在线| 欧美性色综合网| 欧美va日韩va| 亚洲欧美自拍偷拍| 免费欧美高清视频| 成a人片亚洲日本久久| 欧洲一区二区三区在线| 精品久久久久久久久久久院品网| 国产精品免费视频网站| 日本亚洲一区二区| 成人性色生活片免费看爆迷你毛片| 在线精品观看国产| 国产亚洲综合色| 亚洲国产乱码最新视频| 麻豆精品一区二区三区| 国产精品国产a| 国产精品色婷婷| 老司机精品视频导航| 91久久精品一区二区| 久久久久久久性| 日韩国产精品久久久| 成人网男人的天堂| 精品国产91九色蝌蚪| 亚洲已满18点击进入久久| 国产成人三级在线观看| 欧美一区二区三区视频在线观看| 国产精品乱人伦一区二区| 国精品**一区二区三区在线蜜桃| 欧美日韩一区不卡| 亚洲国产精品久久一线不卡| 一本色道**综合亚洲精品蜜桃冫| 国产三级一区二区三区| 国产综合色精品一区二区三区| 欧美精品日韩一本| 午夜久久久久久| 欧美一区二区三区免费视频 | 亚洲成人av免费| 911精品国产一区二区在线| 五月天一区二区| 欧美人牲a欧美精品| 日本成人中文字幕在线视频 | 久久99国产乱子伦精品免费| 91精品国产综合久久久蜜臀粉嫩| 亚洲福利视频导航| 4438x亚洲最大成人网| 日本美女一区二区三区视频| 久久先锋资源网| 成人不卡免费av| 亚洲一区在线观看视频| 欧美日韩一卡二卡| 国产一区在线观看视频| 国产精品久久久久久久蜜臀| 色综合久久久久综合体桃花网| 亚洲一区二区三区小说| 精品人在线二区三区| 不卡免费追剧大全电视剧网站| 亚洲欧美日韩国产手机在线| 91精品国产色综合久久ai换脸 | 久久综合色鬼综合色| 久久se这里有精品|