c语言,结构体复制

structbook{intnum;charname[100];charperson[100];charabout[100];intp;intn;}book[1000];... struct book
{
int num;
char name[100];
char person[100];
char about[100];
int p;
int n;

}book[1000];
因为需要按p的大小排序,自己另外也建了一个结构体,但是感觉操作起来好困难,求大神帮忙!!!1
展开
 我来答
wuzongxian0010
推荐于2017-11-26 · TA获得超过796个赞
知道小有建树答主
回答量:433
采纳率:100%
帮助的人:333万
展开全部
使用memcpy即可, 比如你另外建立一个结构体sortbook[1000]用来保存排序结果,将book中的第i个元素赋值到sortbook的第j个元素中
memcpy(&sortbook[j], &book[i], sizeof(struct book));
用这个函数需要#include <string.h>
3月饼88758傲适
2014-07-02 · 超过68用户采纳过TA的回答
知道答主
回答量:145
采纳率:100%
帮助的人:61.2万
展开全部
不会的,在实例化A的时候会把A中的属于B部分的一起申请内存
你是通过什么方法来发现A.b没有拷贝进去的?
有代码最好贴出来,大家可以一起分析。
你这样直接说结果别人也没办法的
希望能解决您的问题。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
忽忽上升
2014-07-02 · TA获得超过1911个赞
知道小有建树答主
回答量:1166
采纳率:70%
帮助的人:575万
展开全部
结构体排序很容易啊。
#include<algrithm>
bool cmp(book m, book n)
{
return m.p>n.p;
}
sort(book,book+1000,cmp);
更多追问追答
追问
能不能讲解一下
追答
用的STL的库函数sort();
cmp()是自己定义的排序规则,按照p从大到小排序你的book类数组。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式