标题:请问怎样才能将代码与界面连接起来,谢谢
只看楼主
sushengzhou
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2006-6-15
 问题点数:0 回复次数:9 
请问怎样才能将代码与界面连接起来,谢谢

最近要交个课程设计,就是搞一个计数器,是个只有加减乘除的计数器,代码有了,界面也搞好了,因为还没学得很好就不懂怎样才能将代码与界面连接起来,非常希望有朋友帮一下忙,谢谢了
下面是代码
#include<iostream>
using namespace std;
#define TRUE 1
#define FALSE 0
#define MAXNUM 100
typedef int DataType;
struct SeqStack
{ DataType s[MAXNUM];
int t;
};
typedef struct SeqStack *PSeqStack;
PSeqStack createEmptyStack_seq()
{
PSeqStack pastack;
pastack = (PSeqStack)malloc(sizeof(struct SeqStack));
if (pastack == NULL)
printf("Out of space!!\n");
else
pastack->t = -1;
return pastack;
} int isEmptyStack_seq(PSeqStack pastack)
{
return pastack->t == -1;
} void push_seq(PSeqStack pastack, DataType x)
{
if (pastack->t >= MAXNUM - 1)
printf("Overflow!\n");
else
{
pastack->t = pastack->t + 1;
pastack->s[pastack->t] = x;
}
} void pop_seq(PSeqStack pastack)
{
if (pastack->t == -1)
printf("Underflow!\n");
else
pastack->t = pastack->t - 1;
} DataType top_seq(PSeqStack pastack)
{
return pastack->s[pastack->t];
} int infixtoSuffix(const char * infix, char * suffix)
{ /*将中缀表达式转换为后缀表达式,顺利转换返回true,若转换过程中发现中缀表达式非法则返回false*/
int state_int = FALSE;
/*state_int记录状态,等于true表示刚读入的是数字字符,等于false表示刚读入的不是数字字符,
设置这个变量是为了在每输出一个整数后输出一个空格,以免连续输出的两个整数混在一起。*/
char c, c2;
PSeqStack ps = createEmptyStack_seq(); /*运算符栈*/
int i, j = 0;
if (infix[0] == '\0')
return FALSE; /*不允许出现空表达式*/
for (i = 0; infix[i] != '\0'; i++)
{
c = infix[i];
switch (c)
{
case ' ':
case '\t':
case '\n':
if (state_int == TRUE)
suffix[j++] = ' ';/*状态从true转换为false时输出一个空格*/
state_int = FALSE;
break; /*遇到空格或制表符忽略*/
case '0':
case '1':
case '2':
case '3':
case '4':
case '5':
case '6':
case '7':
case '8':
case '9':
state_int = TRUE;
suffix[j++] = c; /*遇到数字输出*/
break;
case '(':
if (state_int == TRUE)
suffix[j++] = ' ';/*状态从true转换为false时输出一个空格*/
state_int = FALSE;
push_seq(ps, c); /*遇到左括号,入栈*/
break;
case ')':
if (state_int == TRUE)
suffix[j++] = ' ';/*状态从true转换为false时输出一个空格*/
state_int = FALSE;
c2 = ')';
while (!isEmptyStack_seq(ps))
{
c2 = top_seq(ps);/*取栈顶*/
pop_seq(ps); /*出栈*/
if (c2 == '(')
{
break;
}
suffix[j++] = c2;
}
if (c2 != '(')
{
free(ps);
suffix[j++] = '\0';
return FALSE;
}
break;
case '+':
case '-':
if (state_int == TRUE)
suffix[j++] = ' ';
state_int = FALSE;
while(!isEmptyStack_seq(ps))
{
c2 = top_seq(ps);
if (c2 == '+' || c2 == '-' || c2 == '*' || c2 == '/')
{
pop_seq(ps);
suffix[j++] = c2;
}
else if(c2=='(') break;
}
push_seq(ps, c);
break;
case '*':
case '/':
if (state_int == TRUE)
suffix[j++] = ' ';
state_int = FALSE;
while (!isEmptyStack_seq(ps))
{
c2 = top_seq(ps);
if (c2 == '*' || c2 == '/')
{
pop_seq(ps);
suffix[j++] = c2;
}
else if(c2=='+'||c2=='-'||c2=='(') break;
}
push_seq(ps, c);
break;
default:
free(ps);
suffix[j++] = '\0';
return FALSE;
}
}
if (state_int == TRUE) suffix[j++] = ' ';
while (!isEmptyStack_seq(ps))
{
c2 = top_seq(ps);
pop_seq(ps);
if (c2 == '(')
{
free(ps);
suffix[j++] = '\0';
return FALSE;
}
suffix[j++] = c2;
}
free(ps);
suffix[j++] = '\0';
return TRUE;
} int calculateSuffix(const char * suffix, int * presult)
{

int state_int = FALSE;
PSeqStack ps = createEmptyStack_seq();
int num = 0, num1, num2;
int i;
char c;
for (i = 0; suffix[i] != '\0'; i++)
{
c = suffix[i];
switch (c)
{
case '0':
case '1':
case '2':
case '3':
case '4':
case '5':
case '6':
case '7':
case '8':
case '9':
if (state_int == TRUE)
num = num * 10 + c - '0';
else num = c - '0';
state_int = TRUE;
break;
case ' ':
case'\t':
case '\n':
if (state_int == TRUE)
{
push_seq(ps, num);
state_int = FALSE;
}
break;
case '+':
case '-':
case '*':
case '/':
if (state_int == TRUE)
{
push_seq(ps, num);
state_int = FALSE;
}
if (isEmptyStack_seq(ps))
{
free(ps);
return FALSE;
}
num2 = top_seq(ps);
pop_seq(ps);
if (isEmptyStack_seq(ps))
{
free(ps);
return FALSE;
}
num1 = top_seq(ps);
pop_seq(ps);
if (c == '+')
push_seq(ps, num1 + num2);
if (c == '-')
push_seq(ps, num1 - num2);
if (c == '*')
push_seq(ps, num1 * num2);
if (c == '/')
push_seq(ps, num1 / num2);
break;
default:
free(ps);
return FALSE;
}
}
*presult = top_seq(ps);
pop_seq(ps);
if (!isEmptyStack_seq(ps))
{
free(ps);
return FALSE;
}
free(ps);
return TRUE;
} void getline(char * line, int limit)
{
char c;
int i = 0;
while (i < limit - 1 && (c = getchar()) != EOF && c != '\n')
line[i++] = c;
line[i] = '\0';
}
void main()
{ char c, infix[MAXNUM], suffix[MAXNUM];
int result;
int flag = TRUE;
while (flag == TRUE)
{
cout<<"Plese input an infix expression!\nInput:";
getline(infix, MAXNUM);
if(infixtoSuffix(infix, suffix) == TRUE)
cout<<"suffix:"<<suffix;
else
{
cout<<"Invalid infix!\n";
cout<<"\nContinue? (y/n)";
cin>>c;
if (c == 'n' || c == 'N') flag = FALSE;
while (getchar() != '\n');
cout<<"\n";
continue;
}
if(calculateSuffix(suffix, &result) == TRUE)
cout<<"\nResult:"<<result;
else
cout<<"Invalid suffix!\n";
cout<<"\nContinue? (y/n)";
cin>>c;
if (c == 'n' || c == 'N') flag = FALSE;
while (getchar() != '\n');
cout<<"\n";
}
}

这是界面
搜索更多相关主题的帖子: 计数器 界面 代码 PSeqStack define 
2006-06-15 16:00
sushengzhou
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2006-6-15
得分:0 

有人可以帮帮忙么,真的急!!!!!!

2006-06-15 18:20
ppzzhhsky
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2006-5-17
得分:0 
直接写在界面下面撒

QQ:397115921 TELEPHONE:13518215101 欢迎大家和我一起交流学习,一起进步
2006-06-16 11:53
zhourunfa66
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2006-5-17
得分:0 
什么意思!!!!
我看不明白
应不懂楼上说的话
2006-06-16 13:31
tianykun
Rank: 4
等 级:禁止访问
威 望:11
帖 子:3727
专家分:0
注 册:2005-11-13
得分:0 

先设计好界面了。。再在相应的界面下写代码哦。


离开这里,离开你的视野,归隐到属于我的地方,无论何处
2006-06-22 11:49
C++大粉丝
Rank: 4
等 级:贵宾
威 望:10
帖 子:477
专家分:0
注 册:2004-4-23
得分:0 
你这个是控制台程序,界面就是console窗口。

I am a big fan of c plus plus.
2006-06-22 12:10
遨游
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2006-5-7
得分:0 
谁有Micsoft platform SDK
请发给我
mconfident@126.com
meng_wen_chao@163.com

心灵是不会孤独的
2006-06-22 15:29
myajax95
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:30
帖 子:2978
专家分:0
注 册:2006-3-5
得分:0 
基本的方法就是重新件一个MFC application,作好button之后把你的code 加进去,删掉main(),把每个button的响应函数连上部剩下的函数们。

http://myajax95./
2006-06-24 13:03
cyyx
Rank: 1
等 级:新手上路
帖 子:35
专家分:0
注 册:2006-12-26
得分:0 
8楼的能把具体方法发给我吗?
Email:xupan20@yahoo.com.cn
谢谢

2006-12-26 15:36
smartwind
Rank: 1
等 级:新手上路
威 望:1
帖 子:277
专家分:0
注 册:2006-11-13
得分:0 

需要建一个windows工程(或者MFC工程)
你如果不明白它们怎么用,那还是先看看这方面的介绍或者问老师吧

不过我很奇怪,都要做课程设计了,你难道没接触过windows程序?


2006-12-27 10:45



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-72536-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.186524 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved