整理音乐

Problem Description


请用链表完成下面题目要求。
xiaobai 很喜欢音乐,几年来一直在收集好听的专辑。他有个习惯,每次在听完一首音乐后会给这首音乐打分,而且会隔一段时间给打好分的音乐排一个名次。今天 xiaobai 打开自己的音乐文件夹,发现有很多不同时期打过分的排好序的子音乐文件夹,他想把这些音乐放到一块,组成一个分数有序的序列。由于音乐文件很多,而文件里音乐的数目也是不确定的,怎么帮帮 xiaobai 完成这件工作呢?
   

Input

输入数据第一行为一个整数n(n<1000),代表文件夹的数量。接下来是n个文件夹的信息,每个文件夹信息的第一行是一个数字m(m<=10000),代表这个文件夹里有m首歌,后面m行每行一个歌曲名、分数,之间用空格分开。歌曲名称不超过5个字符。

Output

输出一行,为所有音乐组成的一个序列,音乐只输出名字。

如果音乐分数相同则按照音乐名字典序进行排序。

Example Input

3
4
aaa 60
aab 50
aac 40
aad 30
2
kkk 60
kkd 59
3
qow 70
qwe 60
qqw 20

Example Output

qow aaa kkk qwe kkd aab aac aad qqw



#include <stdio.h>
#include <stdlib.h>
struct node
{
int sc;
char name[6];
struct node *next;
}*head,*head1,*tail,*p,*q;
void print(struct node *head)
{
p=head->next;
while(p!=NULL)
{
if(p->next==NULL)
printf("%s\n",p->name);
else
printf("%s ",p->name);
p=p->next;
}
}
struct node *create(int x)
{
int i;
head=(struct node *)malloc(sizeof(struct node));
head->next=NULL;
tail=head;
for(i=1;i<=x;i++)
{
p=(struct node *)malloc(sizeof(struct node));
p->next=NULL;
scanf("%s %d",p->name,&p->sc);
tail->next=p;
tail=p;
tail->next=NULL;
}
return head;
};
struct node *merge(struct node *head,struct node *head1)
{
p=head->next;
q=head1->next;
head->next=NULL;
free(head1);
tail=head;
while(q&&p)
{
if(p->sc>=q->sc)
{
tail->next=p;
tail=p;
p=p->next;
tail->next=NULL;
}
else
{
tail->next=q;
tail=q;
q=q->next;
tail->next=NULL;
}
}
while(p)
{
tail->next=p;
tail=p;
p=p->next;
tail->next=NULL;
}
while(q)
{
tail->next=q;
tail=q;
q=q->next;
tail->next=NULL;
}
return head;
};
int main()
{
int n,m,i,j;
struct node *h;
struct node *y,*w;
scanf("%d",&n);
scanf("%d",&m);
y=create(m);
for(i=2;i<=n;i++)
{
scanf("%d",&m);
h=create(m);
w=merge(y,h);
y=w;
}
print(y);
return 0;
}
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/509312.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VS2013正在等待所需操作完成

在用VS2013打开解决方案的时候&#xff0c;遇到”正在等待所需操作完成 &#xff0c;此对话框将在操作完成后关闭“一直弹出显示&#xff0c;解决方案无法加载的情况&#xff01;此时需要将与解决方案名字相同的文件全部相同&#xff08;除解决方案文件除外&#xff09;全部删除…

web聊天室实现

后端&#xff1a; package com.jsx.chat;import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.Map; import java.util.concurrent.CopyOnWriteArraySet;import javax.websocket.OnClose; imp…

QPSQL driver not loaded

在用qt连接postgreSQL数据库时&#xff0c;出现驱动无法加载的情况&#xff0c;如下图&#xff1a; 代码&#xff1a;mPgDataBase QSqlDatabase::addDatabase("QPSQL"); 如下如下错误&#xff1a; 解决方案&#xff1a; 网上下载”libpq.dll文件“拷贝至运行文件…

一对一聊天ajax实现

前端页面&#xff1a; 好友列表&#xff1a; 好友列表代码&#xff1a; <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <% page import"java.util.Random" %> <% taglib ur…

选票统计

Problem Description 某校学生会主席由全校学生投票选举产生&#xff0c;共有&#xff4d;名候选人报名参选&#xff0c;编号为1到&#xff4d;&#xff08;0&#xff1c;&#xff4d;&#xff1c;1000&#xff09;&#xff0c;全校有&#xff4e;名学生&#xff08;0&#xff…

“模块计算机类型“x64”与目标计算机类型“X86”冲突解决方案

最近在编译一款开源软件的时候&#xff0c;遇到了“模块计算机类型“x64”与目标计算机类型“X86”冲突的问题&#xff0c;网上查了好多资料&#xff0c;都是配置“链接器-》高级-》目标计算机”和选择X64平台编译器&#xff0c;可是怎么试都不行&#xff0c;最后发现是“命令行…

通用的websocket模板代码

web聊天室后端代码模板: package com.jsx.chat;import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.Map; import java.util.concurrent.CopyOnWriteArraySet;import javax.websocket.OnClos…

最终排名

Time Limit: 1000MS Memory Limit: 65536KBSubmit StatisticProblem Description 第四届山东理工大学ACM网络编程擂台赛比赛完后需要产生一个最终排名&#xff0c;排名按照题数多少来决定。但是有太多的队伍参与&#xff0c;手动计算排名已经不能满足比赛的需求。现在有一份名单…

windows稀疏文件

稀疏文件(Sparse File), 指的是文件中出现大量的0数据&#xff0c;这些数据对我们用处不大&#xff0c;但是却一样的占用我们的空间&#xff0c;针对此&#xff0c;WINNT 3.51中的NTFS文件系统对此进行了优化&#xff0c;那些无用的0字节被用一定的算法压缩起来&#xff0c;使得…

设置三个线程顺序打印数字问题(转载)

第一种方法&#xff1a;通过共享对象锁的方式实现 记住调用wait方法时候需要在同步代码块内&#xff0c;否则会报java.lang.IllegalMonitorStateException异常&#xff01; package com.test;class Prints {public int num 0;synchronized public void methodA() throws Int…

英文金曲大赛

Problem Description 我们在“渊子数”的题目中已经了解了渊子是个什么样的人了&#xff0c;他在大一的时候参加过工商学院的“英语聚乐部”。告诉你个秘密&#xff0c;这个俱乐部是个好地方&#xff0c;不但活动精彩而且有MM。这不&#xff0c;英语俱乐部举办了一个叫做“英文…

磁盘管理之逻辑卷管理(Logical Volume Manager)

LVM是逻辑卷管理&#xff08;Logical Volume Manager&#xff09;的简称&#xff0c;它是建立在物理存储设备之上的一个抽象层&#xff0c;允许你生成逻辑存储卷,与直接使用物理存储在管理上相比,提供了更好灵活性。 LVM将存储虚拟化,使用逻辑卷,你不会受限于物理磁盘的大小,另…

单链表头插法与尾插法的c语言实现(回顾)

#include<stdio.h> #include<math.h> #include<stdlib.h> typedef struct node{int data;node *next; }; int main() {node *head NULL;node *tail NULL;node *p NULL;p (node *)malloc(sizeof(node));if(pNULL){printf("%s","没有足够的…

磁盘“簇”

“簇”是DOS进行分配的最小单位。当创建一个很小的文件时&#xff0c;如是一个字节&#xff0c;则它在磁盘上并不是只占一个字节的空间&#xff0c;而是占有整个一簇。DOS视不同的存储介质&#xff08;如软盘&#xff0c;硬盘&#xff09;&#xff0c;不同容量的硬盘&#xff0…

选夫婿1

Problem Description 倾国倾城的大家闺秀潘小姐要选夫婿啦&#xff01;武林中各门各派&#xff0c;武林外各大户人家&#xff0c;闻讯纷纷前来&#xff0c;强势围观。前来参与竞选的男生藏龙卧虎&#xff0c;高手云集&#xff0c;才子遍布&#xff0c;帅哥纷纭&#xff0c;更不…

找出二维数组中每行的最小数但最小数的列不能相同

现有一个M*N的表格&#xff0c;请统计表格中每行最小数值之和。要求最小数的都在不同列中&#xff0c; 既假设第一行第一列数是最小数&#xff0c;那即使第二行第一列的数在第二行中不去计算。 example: 存在如下表格&#xff1a; 1 2 3 2 4 5 则&#xff1a; 第一行最小…

Qt实现Word文档界面样式--QtitanRibbon

QtitanRibbon - Microsoft Ribbon for Nokias Qt概念的实现 QtitanRibbon组件实现了Microsoft Ribbon for Qt的概念&#xff0c;设计用于任何使用Qt开发的商业应用。这个组件和Qt一道为获取一些应用提供了一个难得的机会&#xff0c;这些应用在全球三大主要平台Windows、Linux和…

选夫婿2

Problem Description 倾国倾城的大家闺秀潘小姐要选夫婿啦&#xff01;武林中各门各派&#xff0c;武林外各大户人家&#xff0c;闻讯纷纷前来&#xff0c;强势围观。前来参与竞选的男生藏龙卧虎&#xff0c;高手云集&#xff0c;才子遍布&#xff0c;帅哥纷纭&#xff0c;更不…

Unity3d访问数据库

找到System.Data.dll文件&#xff0c;默认的地址是在C:\Program Files\Unity\Editor\Data\Mono\lib\mono\unity&#xff0c;这个根据你所安装的路径有关。 2、将该文件复制到你的工作空间下的Asset文件夹内 3、在你的编辑器中添加引用&#xff0c;我用的是VS 4、在命名空间内

轻松反编译C#的DLL

深入了解Unity&#xff0c;需要知道它内部是怎样工作的&#xff0c;API的代码长什么样&#xff0c;本文以UnityEditor.dll为例&#xff0c;演示如何轻松搞定C#库的反编译。 使用的软件是jetbrains系的doPeek&#xff0c;.NET Reflector 9.0也能做同样的工作&#xff0c;但不太推…