c语言输出单身狗的程序,1065 单身狗 (25分)C语言

单身狗”是中文对于单身人士的一种爱称。本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱。

输入格式:

输入第一行给出一个正整数 N(≤ 50 000),是已知夫妻/伴侣的对数;随后 N 行,每行给出一对夫妻/伴侣——为方便起见,每人对应一个 ID 号,为 5 位数字(从 00000 到 99999),ID 间以空格分隔;之后给出一个正整数 M(≤ 10 000),为参加派对的总人数;随后一行给出这 M 位客人的 ID,以空格分隔。题目保证无人重婚或脚踩两条船。

输出格式:

首先第一行输出落单客人的总人数;随后第二行按 ID 递增顺序列出落单的客人。ID 间用 1 个空格分隔,行的首尾不得有多余空格。

输入样例:

3

11111 22222

33333 44444

55555 66666

7

55555 44444 10000 88888 22222 11111 23333

输出样例:

5

10000 23333 44444 55555 88888

思路

用 -1 当初始值,均为单身狗(因为有 0 号客人,所以最好不用 0 当初始值)

用数组映射一对伴侣

用 -2 表示客人到场。读取客人入场,用映射寻找自己的伴侣,当自己单身或伴侣还未到场,自己-用 -2 表示到场

若映射的伴侣状态为 -2 到场,则两人配对成功,两人用 -3 表示脱离单身狗标签,单身狗数目减二

#include

int main(){

int n,m,i,id1,id2,count=0,arr[100000];

for(i=0;i<100000;i++){

arr[i]=-1;//均为单身狗

}

scanf("%d",&n);

for(i=0;i

scanf("%d %d",&id1,&id2);

arr[id1]=id2;

arr[id2]=id1;

}

scanf("%d",&m);

for(i=0;i

scanf("%d",&id1);

if(arr[id1]>=0){//如果有配偶

arr[id1] = -2;//判断配偶是否到场的条件

}

else{

arr[id1] = -3,count++;//判断单身的条件

}

}

for(i=0;i<100000;i++){

if(arr[i]>=0&&arr[arr[i]] == -2){

arr[arr[i]] = -3,count++;

}

}

printf("%d\n",count);

for(i=0;i<100000;i++){

if(arr[i]== -3){

printf("%05d%c", i, --count ? ' ' : '\0');

}

} //‘\0’,即空字符。判断一个字符串是否结束的标志就是看是否遇到‘\0’,如果遇到‘\0’,则表示字符串结束。

return 0;

}

PAT Basic 1065 单身狗 (25 分)

“单身狗”是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数 N(≤ 50 000),是已知夫妻/伴侣的对数:随后 N ...

PAT1065 单身狗 (25分) 思路记录——参考大神柳婼

1065 单身狗 (25分)   “单身狗”是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数 N(≤ 50 000), ...

PAT乙级 1065. 单身狗(25) by Python

1065. 单身狗(25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue "单身狗"是中文对 ...

PAT 1065. 单身狗(25)

“单身狗”是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数N(<=50000),是已知夫妻/伴侣的对数:随后N行 ...

PAT(B) 1065 单身狗(Java:17分,C:25分)

题目链接:1065 单身狗 (25 point(s)) 题目描述 "单身狗"是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式 ...

PAT 乙级 1065 单身狗 (25 分)

1065 单身狗 (25 分) “单身狗”是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数 N(≤ 50 000),是 ...

PAT 1065 单身狗(25)(STL-map+思路+测试点分析)

1065 单身狗(25 分) "单身狗"是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数 N(≤  ...

PAT Basic 1065 单身狗

单身狗(25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue "单身狗"是中文对于单身人士的 ...

PAT——1065. 单身狗

“单身狗”是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数N(<=50000),是已知夫妻/伴侣的对数:随后N行 ...

随机推荐

74 partprobe-磁盘管理

partprobe命令用于重读分区表,当出现删除文件后,出现仍然占用空间.可以partprobe在不重启的情况下重读分区. 语法 partprobe (选项) (参数) 选项 -d:不更新内核: -s ...

yii2.0自动登录功能的实现方法

参考地址:http://www.kuitao8.com/20150518/3747.shtml 自动登录的原理很简单.主要就是利用cookie来实现的在第一次登录的时候,如果登录成功并且选中了下次自动 ...

canvas小知识

清单 1. 绘制 canvas 矩形 function drawRect(){ var canvas = document.getElementById('canvas'); if (canvas.g ...

bzoj1965 [Ahoi2005]SHUFFLE 洗牌

Description 为了表彰小联为Samuel星球的探险所做出的贡献,小联被邀请参加Samuel星球近距离载人探险活动. 由于Samuel星球相当遥远,科学家们要在飞船中度过相当长的一段时间,小联 ...

nodeJS之路径PATH模块

前面的话 path模块包含一系列处理和转换文件路径的工具集,通过 require('path') 可用来访问这个模块.本文将详细介绍path模块 路径组成 [path.dirname(p)] 返回路径 ...

Node.js初探之GET方式传输

Node.js初探之GET方式传输 例子:form用GET方法向后台传东西 html文件:

python-3.x-基本数据类型

当前学习版本为: python-3.6-4 代码: """整型 NUMBER""" a = 2 ** 5 b = a + 4 c = a / ...

C# 执行CMD 命令

/// /// 执行CMD 命令 /// /// 命 ...

JPA+Hibernate 3.3 ——增删改查

1.     查找对象   1)  用find()方法查找对象 public void getPerson(){ EntityManagerFactory factory = Persistence. ...

你可能感兴趣的:(c语言输出单身狗的程序)