題目描述
模擬程式型計算器,依次輸入指令,可能包含的指令有
1. 數字:'num x',x為乙個只包含大寫字母和數字的字串,表示乙個當前進製的數
2. 運算指令:'add','sub','mul','div','mod',分別表示加減乘,除法取商,除法取餘
3. 進製轉換指令:'change k',將當前進製轉換為k進製(2≤k≤36)
4. 輸出指令:'equal',以當前進製輸出結果
5. 重置指令:'clear',清除當前數字
指令按照以下規則給出:
數字,運算指令不會連續給出,進製轉換指令,輸出指令,重置指令有可能連續給出
運算指令後出現的第乙個數字,表示參與運算的數字。且在該運算指令和該數字中間不會出現運算指令和輸出指令
重置指令後出現的第乙個數字,表示基礎值。且在重置指令和第乙個數字中間不會出現運算指令和輸出指令
進製轉換指令可能出現在任何地方
運算過程中中間變數均為非負整數,且小於2^63。
以大寫的'a'~'z'表示10~35
輸入第1行:1個n,表示指令數量
第2..n+1行:每行給出一條指令。指令序列一定以'clear'作為開始,並且滿足指令規則
輸出依次給出每一次'equal'得到的結果
樣例輸入
7clear
num 1024
change 2
addnum 100000
change 8
equal
樣例輸出
2040思路:把其他進製先轉成10進製,最後在轉成當前的進製輸出
**:
#include#include#include
#include
#include
#include
#include
#include
#include
#include
const
int maxn=1e5+5
;typedef
long
long
ll;using
namespace
std;
string
st;char str[36
];ll ss;
void tochange(int x,int
jz)
for(int t=cnt-1;t>=0;t--)
cout
<}ll cal(
char x,int
jz)
else
}return
sum;
}stack
op;stack
oop;
intmain()
for(int t=10;t<36;t++)
intn;
cin>>n;
char num[105
];
intcc;
ll xx;
for(int t=0;t)
else
if(st=="
num"
)
else
if(oop.top()=="
sub"
)
else
if(oop.top()=="
mul"
)
else
if(oop.top()=="
div"
)
else
oop.pop();
}else
}else
if(st=="
change")
else
if(st=="
equal")
else
}return0;
}
藍橋杯 2023年第八屆真題 日期問題
題目 題目描述 小明正在整理一批歷史文獻。這些歷史文獻 現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,...
藍橋杯 2023年第八屆真題 分巧克力
題目 題目描述 兒童節那天有k位小朋友到小明家做客。小明拿出了珍藏的巧克力招待小朋友們。小明一共有n塊巧克力,其中第i塊是hi x wi的方格組成的長方形。為了公平起見,小明需要從這 n 塊巧克力中切出k塊巧克力分給小朋友們。切出的巧克力需要滿足 形狀是正方形,邊長是整數 大小相同 例如一塊6x5的...
藍橋杯 2023年第八屆真題 Excel位址
藍橋杯 2017年第八屆真題 excel位址 時間限制 1sec 記憶體限制 128mb 提交 522 解決 192 excel單元格的位址表示很有趣,它使用字母來表示列號。比如,a表示第1列,b表示第2列,z表示第26列,aa表示第27列,ab表示第28列,ba表示第53列,當然excel的最大列...