标题:其他可无视,从main看起,main函数很简单,为什么cout出一个"?"号? ...
只看楼主
最左边那个
Rank: 4
等 级:业余侠客
威 望:3
帖 子:97
专家分:201
注 册:2009-4-24
结帖率:75%
 问题点数:0 回复次数:3 
其他可无视,从main看起,main函数很简单,为什么cout出一个"?"号?
#include<iostream.h>

typedef char datatype;
const int maxsize=100;
struct sqstack
{
    datatype data[maxsize];
    int top;
};

void init_sqstack(sqstack & sq);
int empty_sqstack(sqstack & sq);
int push_sqstack(sqstack & sq,datatype x);
int pop_sqstack(sqstack & sq,datatype x);
void creat_sz(char * &yh,int n);
void Output(char *pa,int n);


void main()
{
    sqstack A;
    init_sqstack(A);
    char *yh=NULL,ch;
    //int n;
    //cin>>n;
    //creat_sz(yh,n);
    //Output(yh,n);
    push_sqstack(A,'1');
    pop_sqstack(A,ch);
    cout<<ch<<endl;
   
   




   

}


void init_sqstack(sqstack  & sq)
{
    sq.top=-1;
}
int empty_sqstack(sqstack & sq)
{
    if(sq.top==-1)  return 1;
    else return 0;
}

int push_sqstack(sqstack & sq,datatype x)
{

    if(sq.top==maxsize-1)
    {
        cout<<"栈满,不能进栈!\n";
        return 0;   
    }
   
    else
    {
        
        sq.data[(sq.top)++]=x;

   
        
        
        return 1;
    }
}

int pop_sqstack(sqstack & sq,datatype x)
{
    if(sq.top==-1)
    {
        cout<<"栈空,不能退栈!\n";
        return 0;
    }
    else
    {
        x=sq.data[sq.top--];
        return 1;
    }

}

void creat_sz(char * &yh,int n)
{
   
    int i=0;
    yh=new char[n+1];
    while(i<n)
    {
        cin>>yh[i];
        i++;
    }
}

void Output(char *pa,int n)
{
    if(pa==NULL)
    {cout<<" allocation faiure\n";}

    for(int i=0;i<n;i++)   
    {
        cout<<pa[i];
    }
    cout<<endl;

}
搜索更多相关主题的帖子: main cout 函数 
2010-05-07 14:26
liubangchuan
该用户已被删除
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2010-05-07 16:55
最近不在
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:204
专家分:842
注 册:2010-2-28
得分:0 
程序代码:
#include "stdafx.h"
#include <iostream>
using namespace std;
#include <stdlib.h>

const int nlen = 4;   //分配初始内存大小
const int nadd = 2;   //内存不足,增加内存

struct stack
{
    int *pa;
    int *pb;
    int nsize;
};

void create(stack &s);
void push(stack &s,int e);   //插入元素
void pop(stack &s, int &e);  //删除元素 
bool empty(stack &s);        //判断栈是否为空
void destory(stack &s);       //销毁栈

int main(int argc, char* argv[])
{
    while(1)
    {
        stack sql;
        create (sql);
        
        cout<<"please input a number:"<<endl;
        
        int nt;
        int e ; 
        cin>>nt;

        if(0 == nt)    //当输入0时,退出循环
        {
            return 0;
        }
        
        while(nt)
        {
            push(sql, nt%8);   //10进制数除以8,余数进栈
            nt = nt/8;
        }
        
        while(!empty(sql))    //余数出栈
        {
            pop(sql, e);
            cout<<e;
        }          
        cout<<endl;
        free(sql.pa);
        //system("cls"); 
        
        //delete [] sql.pa;
    }
    return 0;    
}

void create(stack &s)
{
    //s.pa = new int[nlen];
    s.pa = (int *)malloc(nlen * sizeof(int));
    if(!s.pa)
    {
        return ;
    }
    s.pb = s.pa;
    s.nsize = nlen;
}

void push(stack &s, int e)
{
    if(s.pb - s.pa >= s.nsize)
    {
        //delete [] s.pa;
        //s.pa = NULL;
        //s.pa = new int[(s.nsize + nadd)];
        s.pa = (int *)realloc(s.pa,(s.nsize + nadd) * sizeof(int));
        
        if(!s.pa)
        {
            cout<<"memory error!"<<endl;
        }
        s.pb = s.pa + s.nsize;    
        s.nsize += nadd;    
    }
    *(s.pb++) = e;
}

void pop(stack &s, int &e)
{
    if(s.pa == s.pb)
    {
        cout<<"error"<<endl;
    }
    e = *(--s.pb);
}

bool empty(stack &s)
{
    if(s.pa == s.pb)
    {
        return true;
    }
    else 
        return false;
}

void destory(stack &s)
{

}
2010-05-07 22:52
a17674
Rank: 2
等 级:论坛游民
帖 子:3
专家分:12
注 册:2010-5-8
得分:0 
顶 2 楼
2010-05-08 09:49



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




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

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