栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

zoj 2982 Weird Numbers

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

zoj 2982 Weird Numbers

#include<iostream>#include<string.h>#include<stdio.h>#include<algorithm> using namespace std;enum {    SIZ = 104,    TO  = 0,    FRO = 1,};int base, type, len;char input[SIZ];char output[SIZ];void convTo() {    int sign = 1;    int src = atoi(input), rem;    int pos = src >= 0?1:-1;    if (pos < 0){        src = -src;    }    len = 0;    while(src){        rem = (base + src % base)%base;        if (sign * pos < 0 && rem){ rem = base - rem; src += rem;        } else { src -= rem;        }        output[len++] = '0' + rem;        src /= base;        sign = -sign;    }    if (len == 0){        output[len++] = '0';    }    output[len] = 0;    reverse(output, output + len);    printf("%sn", output);}void convFrom() {    int d = 0;    char *p = input;    while(*p){        d *= -base;        d += *p - '0';        ++p;    }    printf("%dn", d);}void fun(){    if (type == TO){        convTo();    } else {        convFrom();    }}void parsebase(){    char *p = index(input, '-');    *p = 0;    base = atoi(p+1);    if (strcmp(input, "to") == 0) {        type = TO;    } else {        type = FRO;    }}int main(){    scanf("%s ", input);    while(strcmp(input, "end") != 0){        parsebase();        scanf("%s ", input);        fun();        scanf("%s ", input);    }    return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/379503.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号