| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 543 人关注过本帖
标题:【求助】关于指向结构体的指针使用问题
只看楼主 加入收藏
s951360702
Rank: 1
来 自:湖北武汉
等 级:新手上路
帖 子:3
专家分:0
注 册:2013-3-28
结帖率:0
收藏
已结贴  问题点数:20 回复次数:5 
【求助】关于指向结构体的指针使用问题
struct data{

    int xishu;

    int zhishu;

};

struct node{

    data dat;

    node *next;

};

int cmp(const void *a,const void *b)

{

    return ((data*)a)->zhishu-((data*)b)->zhishu;    //这句那个((data*)a)不懂求详细杰斯

}
搜索更多相关主题的帖子: void next return 结构体 
2013-03-28 17:07
s951360702
Rank: 1
来 自:湖北武汉
等 级:新手上路
帖 子:3
专家分:0
注 册:2013-3-28
收藏
得分:0 
这是我在做一元多项式加法时自己网上搜到的跟自己很像的代码,我的代码也出现跟那句去掉*,然后:
1>一元多项式乘法.cpp(26): error C2440: “类型转换”: 无法从“const void *”转换为“data”
2013-03-28 17:09
gfchen1819
Rank: 2
等 级:论坛游民
帖 子:22
专家分:48
注 册:2013-2-20
收藏
得分:7 
如你所说,不能从const void*转void*
新手建议不要用void。。。
2013-03-28 17:23
s951360702
Rank: 1
来 自:湖北武汉
等 级:新手上路
帖 子:3
专家分:0
注 册:2013-3-28
收藏
得分:0 
/*-----------上面代码有个错误print声明时参数与定义是不一样,这两天改昏头了------------------*/
/*---------------------------两个一元多项式相加----------------------------------------------------*/
/*---------------------------用两个链表结构储存----------------------------------------------------*/
/*---------------------------以第一个链表为基础合并在一起实现加法----------------------------------*/
#include<iostream>
using namespace std;
//节点
struct Node{
    float x;        //系数
    int y;            //指数
    Node *next;
};
Node *Creat(Node *p);//创建链表
Node *add(Node *p1,Node *p2);//2个链表相加
void print(Node *p);//打印链表*p
int main()
{
    Node *p1,*p2;
    p1=NULL;
    p2=NULL;
    cout<<"请依次输入第一个一元多项式的系数和指数次数(请按指数从小到大排列输入):"<<endl;
    *Creat(p1);
    cout<<endl<<"请依次输入第二个一元多项式的系数和指数次数(请按指数从小到大排列输入):"<<endl;
    cout<<"按下回车进入加法,并打印结果!"<<endl;
    *Creat(p2);
    *add(p1,p2);
    print(p1);
    system("pause");
    return 0;
}
Node *Creat(Node *p)//创建链表
{
    Node *p1,*p2;
    p=NULL;
    p1=new Node;
    p2=p1;
    cin>>p1->x>>p1->y;
    while(!(p1->x=-1))
    {
        if(p==NULL)
            p=p1;
        else
            p2->next=p1;
        p2=p1;
        p1=new Node;
        cin>>p1->x>>p1->y;
    }
    p2->next=NULL;
    delete p1;
    return p;
}

Node *add(Node *p1,Node *p2)//2个链表相加
{
    Node *p,*q;
    p=p1;
    q=p2;
    while(p->next&&q->next)    //不不尾节点进入循环
    {
        if(p->y==q->y)        //若指数相等
        {
            p->x=p->x+q->x;    //则系数相加
            p=p->next;        //指向下一个节点
            q=q->next;
        }
        else if( p->y < q->y )//若指数小于
        {
            Node *m,*n;
            m=p->next;
            n=q->next;
            p->next=q;        //第一个多项式p->next指向第二个多想是的q节点
            q->next=m;        //修改指针指向操作
            p=m;
            q=n;
        }
        else                //若指数大于同样修改指针指向操作
        {
            Node *m,*n;
            m=p;
            n=q->next;
            p=q;
            q->next=m;
            p=m->next;
            q=n;
        }
    }
    p=p1;                    //返回第一个链表首地址
   
    while(p->y==p->next->y)    //用循环实现消除x^2+x^3与x^1+x^2产生的x^1+x^2+x^2+x^3的情况
    {
        p->x=p->x+p->next->x;
        p->next=p->next->next;
        p=p->next;
        if(p==NULL) break;
    }
    return p1;
}
void print(Node *p)//打印链表
{
    Node *q;
    q=p;
    cout<<"正在打印:"<<endl;
    while(q!=NULL)
    {
        cout<<q->x<<"x exp "<<q->y<<"次+";
        q=q->next;
    }
}

[ 本帖最后由 s951360702 于 2013-3-28 18:45 编辑 ]
2013-03-28 18:34
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:7 
应该是定义个data型的指针变量吧

Maybe
2013-03-28 23:00
shmilyflf
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:5
帖 子:356
专家分:1008
注 册:2012-12-9
收藏
得分:7 
((data*)a)这个是把a强制转换为data结构体指针类型。你要是把int cmp(const void *a,const void *b)这里面的参数改为data结构体类型的就能转换了
2013-03-28 23:21
快速回复:【求助】关于指向结构体的指针使用问题
数据加载中...
 
   



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

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