主頁 > 軟體工程 > 計劃做有優先級的計算器,vc五個lnk2001錯誤,求助呀。

計劃做有優先級的計算器,vc五個lnk2001錯誤,求助呀。

2020-09-15 04:30:04 軟體工程

hanshushixian.obj : error LNK2001: unresolved external symbol "void __cdecl DestroyStack(struct SqStackN * &)" (?DestroyStack@@YAXAAPAUSqStackN@@@Z)
hanshushixian.obj : error LNK2001: unresolved external symbol "bool __cdecl GetTop(struct SqStackN *,double &)" (?GetTop@@YA_NPAUSqStackN@@AAN@Z)
hanshushixian.obj : error LNK2001: unresolved external symbol "bool __cdecl Push(struct SqStackN * &,double)" (?Push@@YA_NAAPAUSqStackN@@N@Z)
hanshushixian.obj : error LNK2001: unresolved external symbol "bool __cdecl Pop(struct SqStackN * &,double &)" (?Pop@@YA_NAAPAUSqStackN@@AAN@Z)
hanshushixian.obj : error LNK2001: unresolved external symbol "void __cdecl initStack(struct SqStackN * &)" (?initStack@@YAXAAPAUSqStackN@@@Z)
Debug/y8210181709.exe : fatal error LNK1120: 5 unresolved externals
執行 link.exe 時出錯.



基本想法是搞個堆疊,利用堆疊進行計算,在堆疊計算后綴運算式時出現錯誤,上面是vc報錯,下面是我的堆疊計算后綴函式。

double calculate(char* postexp)
{
double a,b,c,d,e;
SqStackN *o;initStack(o);
while(*postexp!='\0') 
{
switch(*postexp)
{
case'+':
Pop(o,a);
Pop(o,b);
c= b+a;
Push(o,c);
break;
case'-':
Pop(o,a);
Pop(o,b);
c=b-a;
Push(o,c);
break;
case'*':
Pop(o,a);
Pop(o,b);
c=b*a;
Push(o,c);
break;
case '/':
Pop(o,a);
Pop(o,b);
if(a!=0) 
{
c=b/a;
Push(o,c);
break;
}
else
{
exit(0);
}
break;
default:
d=0;
while (*postexp>='0'&&*postexp<='9') 
{
d=d*10+(*postexp-'0');
postexp++;
}
Push(o,d);
break;
}
postexp++;
}
GetTop(o,e);
DestroyStack(o);
return(e);
}

uj5u.com熱心網友回復:

僅供參考:
#pragma warning(disable:4996)
/*---------------------------------------
函式型計算器(VC++6.0,Win32 Console)
功能:
目前提供了10多個常用數學函式:
⑴正弦sin
⑵余弦cos
⑶正切tan
⑷開平方sqrt
⑸反正弦arcsin
⑹反余弦arccos
⑺反正切arctan
⑻常用對數lg
⑼自然對數ln
⑽e指數exp
⑾乘冪函式^
⑿向上取整ceil
⒀向下取整floor
⒁四舍五入取整round
用法:
如果要求2的32次冪,可以打入2^32<回車>
如果要求30度角的正切可鍵入tan(Pi/6)<回車>
注意不能打入:tan(30)<Enter>
如果要求1.23弧度的正弦,有幾種方法都有效:
sin(1.23)<Enter>
sin 1.23 <Enter>
sin1.23  <Enter>
如果驗證正余弦的平方和公式,可打入sin(1.23)^2+cos(1.23)^2 <Enter>或sin1.23^2+cos1.23^2 <Enter>
此外兩函式運算式連在一起,自動理解為相乘如:sin1.23cos0.77+cos1.23sin0.77就等價于sin(1.23)*cos(0.77)+cos(1.23)*sin(0.77)
當然你還可以依據三角變換,再用sin(1.23+0.77)也即sin2驗證一下。
本計算器充分考慮了運算子的優先級因此諸如:2+3*4^2 實際上相當于:2+(3*(4*4))
另外函式名前面如果是數字,那么自動認為二者相乘.
同理,如果某數的右側是左括號,則自動認為該數與括弧項之間隱含一乘號。
如:3sin1.2^2+5cos2.1^2 相當于3*sin2(1.2)+5*cos2(2.1)
又如:4(3-2(sqrt5-1)+ln2)+lg5 相當于4*(3-2*(√5 -1)+loge(2))+log10(5)
此外,本計算器提供了圓周率Pi鍵入字母時不區分大小寫,以方便使用。
16進制整數以0x或0X開頭。
----------------------------------------*/
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <cstring>
#include <cctype>
#include <cmath>
#include <stdio.h>
#include <string.h>
#include <windows.h>
using namespace std;
const char Tab = 0x9;
const int  DIGIT = 1;
const int MAXLEN = 16384;
char s[MAXLEN], *endss;
int pcs = 15;
double round(double dVal, short iPlaces) {//iPlaces>=0
char s[30];
double dRetval;

sprintf(s, "%.*lf", iPlaces, dVal);
sscanf(s, "%lf", &dRetval);
return (dRetval);
}
double fun(double x, char op[], int *iop) {
while (op[*iop - 1]<32) //本行使得函式嵌套呼叫時不必加括號,如 arc sin(sin(1.234)) 只需鍵入arc sin sin 1.234<Enter>
switch (op[*iop - 1]) {
case  7: x = sin(x);    (*iop)--; break;
case  8: x = cos(x);    (*iop)--; break;
case  9: x = tan(x);    (*iop)--; break;
case 10: x = sqrt(x);   (*iop)--; break;
case 11: x = asin(x);   (*iop)--; break;
case 12: x = acos(x);   (*iop)--; break;
case 13: x = atan(x);   (*iop)--; break;
case 14: x = log10(x);  (*iop)--; break;
case 15: x = log(x);    (*iop)--; break;
case 16: x = exp(x);    (*iop)--; break;
case 17: x = ceil(x);   (*iop)--; break;
case 18: x = floor(x);  (*iop)--; break;
case 19: x = round(x, 0); (*iop)--; break;
}
return x;
}
double calc(char *expr, char **addr) {
static int deep; //遞回深度
static char *fname[] = { "sin","cos","tan","sqrt","arcsin","arccos","arctan","lg","ln","exp","ceil","floor","round",NULL };
double ST[10] = { 0.0 }; //數字堆疊
char op[10] = { '+' }; //運算子堆疊
char c, *rexp, *pp, *pf;
int ist = 1, iop = 1, last, i, n;
__int64 i64;

if (!deep) {
pp = pf = expr;
do {
c = *pp++;
if (c != ' '&& c != Tab)
*pf++ = c;
} while (c != '\0');
}
pp = expr;
if ((c = *pp) == '-' || c == '+') {
op[0] = c;
pp++;
}
last = !DIGIT;
while ((c = *pp) != '\0') {
if (c == '(') {//左圓括弧
deep++;
ST[ist++] = calc(++pp, addr);
deep--;
ST[ist - 1] = fun(ST[ist - 1], op, &iop);
pp = *addr;
last = DIGIT;
if (*pp == '(' || isalpha(*pp) && strnicmp(pp, "Pi", 2)) {//目的是:當右圓括弧的右惻為左圓括弧或函式名字時,默認其為乘法
op[iop++] = '*';
last = !DIGIT;
c = op[--iop];
goto operate;
}
}
else if (c == ')') {//右圓括弧
pp++;
break;
}
else if (isalpha(c)) {
if (!strnicmp(pp, "Pi", 2)) {
if (last == DIGIT) {
wcout << L"π左側遇)" << endl; exit(1);
}
ST[ist++] = 3.14159265358979323846264338328;
ST[ist - 1] = fun(ST[ist - 1], op, &iop);
pp += 2;
last = DIGIT;
if (!strnicmp(pp, "Pi", 2)) {
wcout << L"兩個π相連" << endl; exit(2);
}
if (*pp == '(') {
wcout << L"π右側遇(" << endl; exit(3);
}
}
else {
for (i = 0; (pf = fname[i]) != NULL; i++)
if (!strnicmp(pp, pf, strlen(pf))) break;
if (pf != NULL) {
op[iop++] = 07 + i;
pp += strlen(pf);
}
else {
wcout << L"陌生函式名" << endl; exit(4);
}
}
}
else if (c == '+' || c == '-' || c == '*' || c == '/' || c == '%' || c == '^') {
char cc;
if (last != DIGIT) {
wcout << L"運算子粘連" << endl; exit(5);
}
pp++;
if (c == '+' || c == '-') {
do {
cc = op[--iop];
--ist;
switch (cc) {
case '+':  ST[ist - 1] += ST[ist]; break;
case '-':  ST[ist - 1] -= ST[ist]; break;
case '*':  ST[ist - 1] *= ST[ist]; break;
case '/':  ST[ist - 1] /= ST[ist]; break;
case '%':  ST[ist - 1] = fmod(ST[ist - 1], ST[ist]); break;
case '^':  ST[ist - 1] = pow(ST[ist - 1], ST[ist]); break;
}
} while (iop);
op[iop++] = c;
}
else if (c == '*' || c == '/' || c == '%') {
operate: cc = op[iop - 1];
if (cc == '+' || cc == '-') {
op[iop++] = c;
}
else {
--ist;
op[iop - 1] = c;
switch (cc) {
case '*':  ST[ist - 1] *= ST[ist]; break;
case '/':  ST[ist - 1] /= ST[ist]; break;
case '%':  ST[ist - 1] = fmod(ST[ist - 1], ST[ist]); break;
case '^':  ST[ist - 1] = pow(ST[ist - 1], ST[ist]); break;
}
}
}
else {
cc = op[iop - 1];
if (cc == '^') {
wcout << L"乘冪符連用" << endl; exit(6);
}
op[iop++] = c;
}
last = !DIGIT;
}
else {
if (last == DIGIT) {
wcout << L"兩數字粘連" << endl; exit(7);
}
if (pp[0] == '0' && (pp[1] == 'x' || pp[1] == 'X')) {
sscanf(pp + 2, "%I64x%n", &i64, &n);
rexp = pp + 2 + n;
ST[ist++] = (double)i64;
}
else ST[ist++] = strtod(pp, &rexp);
ST[ist - 1] = fun(ST[ist - 1], op, &iop);
if (pp == rexp) {
wcout << L"非法字符" << endl; exit(8);
}
pp = rexp;
last = DIGIT;
if (*pp == '(' || isalpha(*pp)) {
op[iop++] = '*';
last = !DIGIT;
c = op[--iop];
goto operate;
}
}
}
*addr = pp;
if (iop >= ist) {
wcout << L"運算式有誤" << endl; exit(9);
}
while (iop) {
--ist;
switch (op[--iop]) {
case '+':  ST[ist - 1] += ST[ist]; break;
case '-':  ST[ist - 1] -= ST[ist]; break;
case '*':  ST[ist - 1] *= ST[ist]; break;
case '/':  ST[ist - 1] /= ST[ist]; break;
case '%':  ST[ist - 1] = fmod(ST[ist - 1], ST[ist]); break;
case '^':  ST[ist - 1] = pow(ST[ist - 1], ST[ist]); break;
}
}
return ST[0];
}
int main(int argc, char **argv) {
int a;

wcout.imbue(locale("chs"));
if (argc<2) {
//if (GetConsoleOutputCP() != 936) system("chcp 936>NUL");//中文代碼頁
wcout << L"計算函式運算式的值。" << endl << L"支持(),+,-,*,/,%,^,Pi,sin,cos,tan,sqrt,arcsin,arccos,arctan,lg,ln,exp,ceil,floor,round" << endl;
while (1) {
wcout << L"請輸入運算式:";
fgets(s,16384,stdin);
if ('\n' == s[strlen(s)-1]) s[strlen(s) - 1] = 0;
if (s[0] == 0) break;//
cout << s << "=";
cout << setprecision(15) << calc(s, &endss) << endl;
}
}
else if (argc == 2 && 0 == strcmp(argv[1], "/?")) {
//if (GetConsoleOutputCP() != 936) system("chcp 936>NUL");//中文代碼頁
wcout << L"計算由≥1個命令列引數給出的函式運算式的值。\n"
"最后一個引數是.0~.15表示將計算結果保留小數0~15位\n"
"最后一個引數是x表示將計算結果以16進制正整數格式輸出\n"
"支持(),+,-,*,/,%,^^,Pi,sin,cos,tan,sqrt,arcsin,arccos,arctan,lg,ln,exp,ceil,floor,round\n"
"16進制整數以0x或0X開頭\n";
}
else {
strncpy(s, argv[1], MAXLEN - 1); s[MAXLEN - 1] = 0;
if (argc>2) {
for (a = 2; a<argc - 1; a++) strncat(s, argv[a], MAXLEN - 1);//將空格間隔的各引數連接到s
if (1 == sscanf(argv[a], ".%d", &pcs) && 0 <= pcs && pcs <= 15) {//最后一個引數是.0~.15表示將計算結果保留小數0~15位
printf("%.*lf\n", pcs, calc(s, &endss));
}
else if (argv[a][0] == 'x' || argv[a][0] == 'X') {//最后一個引數是x表示將計算結果以16進制正整數格式輸出
printf("0x%016I64x\n", (__int64)calc(s, &endss));
}
else {
strncat(s, argv[a], MAXLEN - 1);
printf("%.15lg\n", calc(s, &endss));
}
}
else {
printf("%.15lg\n", calc(s, &endss));
}
}
return 0;
}

uj5u.com熱心網友回復:

老師這個是???、我是菜鳥,零基礎,可以給我一個解題思路嗎

uj5u.com熱心網友回復:

我不知道如何解決這個問題

轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/42169.html

標籤:基礎類

上一篇:Vs

下一篇:單檔案視窗的影片特效

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • Git本地庫既關聯GitHub又關聯Gitee

    創建代碼倉庫 使用gitee舉例(github和gitee差不多) 1.在gitee右上角點擊+,選擇新建倉庫 ? 2.選擇填寫倉庫資訊,然后進行創建 ? 3.服務端已經準備好了,本地開始作準備 (1)Git 全域設定 git config --global user.name "成鈺" git c ......

    uj5u.com 2020-09-10 05:04:14 more
  • CODING DevOps 代碼質量實戰系列第二課,相約周三

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。**《DevOps 代碼質量實戰(PHP 版)》**為 CODING DevOps 代碼質量實戰系列的第二課,同時也是本系列的 PHP ......

    uj5u.com 2020-09-10 05:07:43 more
  • 推薦Scrum書籍

    推薦Scrum書籍 直接上干貨,推薦書籍清單如下(推薦有順序的哦) Scrum指南 Scrum精髓 Scrum敏捷軟體開發 Scrum捷徑 硝煙中的Scrum和XP : 我們如何實施Scrum 敏捷軟體開發:Scrum實戰指南 Scrum要素 大規模Scrum:大規模敏捷組織的設計 用戶故事地圖 用 ......

    uj5u.com 2020-09-10 05:07:45 more
  • CODING DevOps 代碼質量實戰系列最后一課,周四發車

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。 **《DevOps 代碼質量實戰(Java 版)》**為 CODING DevOps 代碼質量實戰系列的最后一課,同時也是本系列的 ......

    uj5u.com 2020-09-10 05:07:52 more
  • 敏捷軟體工程實踐書籍

    Scrum轉型想要做好,第一步先了解并真正落實Scrum,那么我推薦的Scrum書籍是要看懂并實踐的。第二步是團隊的工程實踐要做扎實。 下面推薦工程實踐書單: 重構:改善既有代碼的設計 決議極限編程 : 擁抱變化 代碼整潔代碼 程式員的職業素養 修改代碼的藝術 撰寫可讀代碼的藝術 測驗驅動開發 : ......

    uj5u.com 2020-09-10 05:07:55 more
  • Jenkins+svn+nginx實作windows環境自動部署vue前端專案

    前面文章介紹了Jenkins+svn+tomcat實作自動化部署,現在終于有空抽時間出來寫下Jenkins+svn+nginx實作自動部署vue前端專案。 jenkins的安裝和配置已經在前面文章進行介紹,下面介紹實作vue前端專案需要進行的哪些額外的步驟。 注意:在安裝jenkins和nginx的 ......

    uj5u.com 2020-09-10 05:08:49 more
  • CODING DevOps 微服務專案實戰系列第一課,明天等你

    CODING DevOps 微服務專案實戰系列第一課**《DevOps 微服務專案實戰:DevOps 初體驗》**將由 CODING DevOps 開發工程師 王寬老師 向大家介紹 DevOps 的基本理念,并探討為什么現代開發活動需要 DevOps,同時將以 eShopOnContainers 項 ......

    uj5u.com 2020-09-10 05:09:14 more
  • CODING DevOps 微服務專案實戰系列第二課來啦!

    近年來,工程專案的結構越來越復雜,需要接入合適的持續集成流水線形式,才能滿足更多變的需求,那么如何優雅地使用 CI 能力提升生產效率呢?CODING DevOps 微服務專案實戰系列第二課 《DevOps 微服務專案實戰:CI 進階用法》 將由 CODING DevOps 全堆疊工程師 何晨哲老師 向 ......

    uj5u.com 2020-09-10 05:09:33 more
  • CODING DevOps 微服務專案實戰系列最后一課,周四開講!

    隨著軟體工程越來越復雜化,如何在 Kubernetes 集群進行灰度發布成為了生產部署的”必修課“,而如何實作安全可控、自動化的灰度發布也成為了持續部署重點關注的問題。CODING DevOps 微服務專案實戰系列最后一課:**《DevOps 微服務專案實戰:基于 Nginx-ingress 的自動 ......

    uj5u.com 2020-09-10 05:10:00 more
  • CODING 儀表盤功能正式推出,實作作業資料可視化!

    CODING 儀表盤功能現已正式推出!該功能旨在用一張張統計卡片的形式,統計并展示使用 CODING 中所產生的資料。這意味著無需額外的設定,就可以收集歸納寶貴的作業資料并予之量化分析。這些海量的資料皆會以圖表或串列的方式躍然紙上,方便團隊成員隨時查看各專案的進度、狀態和指標,云端協作迎來真正意義上 ......

    uj5u.com 2020-09-10 05:11:01 more
最新发布
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:41:12 more
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:35:34 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:05:44 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:00:18 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:20:31 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:55 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:18:51 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:00 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:17:55 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:12:06 more