CCF认证 20160902 火车购票

本文介绍了一种使用一维数组实现的座位分配算法,通过遍历数组查找满足购票需求的排数,从该排起始编号输出连续递增的座位编号。若无单一排能满足需求,则从多个排中输出剩余座位,直至满足购票总数。

在这里插入图片描述
定义一个长度为20的一维数组a 表示每排剩余的座位数量,那么第 i 排剩余座位的起始编号就应该是i*5+6-a[i]。每次给定一个购票数量x,就遍历数组a查找有无剩余座位数量大于等于x的元素,有则从起始编号输出x个递增的数字,若没有则从有剩余座位的每一排中输出其所有剩余座位直至输出座位总数为x。

#include <bits/stdc++.h>
using namespace std;
const int maxn = 20;
int a[maxn];//每排剩余座位数
int main() {
	int n;cin>>n;
	//memset(a,5,sizeof(a));//不能用它将int数组初始化为0和-1之外的其他值
	for(int i=0;i<maxn;i++)	a[i]=5;
	while(n--){
		int x;cin>>x;
		int i=0;
		while(i<20&&a[i]<x)++i;//查找是否有剩余座位数多于x的排
		if(i<20){//有,从该排起始编号开始输出k个连续递增数字
			int start=i*5+6-a[i];//计算座位标号
			for(int j=0;j<x;j++)
				cout<<start+j<<' ';
			a[i]-=x;//更新剩余座位数
		}
		else{//没有,从有剩余座位的排中输出空闲座位直至输出空余座位总数为x
			for(int j=0;j<20&&x>0;++j)
				if(a[j]){//有剩余座位
					int start=j*5+6-a[j];
					for(int k=0;k<min(a[j],x);++k)
						cout<<start+k<<' ';
					a[j]=x>a[j]?0:a[j]-x;//更新座位数
					x-=a[j];//更新剩余要选座位数
				}
		}
		cout<<endl;
	}
	return 0;
}
下载前可以先看下教程 https://pan.quark.cn/s/16a53f4bd595 小天才电话手表刷机教程 — 基础篇 我们将为您简单的介绍小天才电话手表新机型的简单刷机以及玩法,如adb工具的使用,magisk的刷入等等。 我们会确保您看完此教程后能够对Android系统有一个最基本的认识,以及能够成功通过magisk root您的手表,并安装您需要的第三方软件。 ADB Android Debug Bridge,简称,在android developer的adb文档中是这么描述它的: 是一种多功能命令行工具,可让您与设备进行通信。 该命令有助于各种设备操作,例如安装和调试应用程序。 提供对 Unix shell 的访问,您可以使用它在设备上运行各种命令。 它是一个客户端-服务器程序。 这听起来有些难以理解,因为您也没有必要去理解它,如果您对本文中的任何关键名词产生疑惑或兴趣,您都可以在搜索引擎中去搜索它,当然,我们会对其进行简单的解释:是一款在命令行中运行的,用于对Android设备进行调试的工具,并拥有比一般用户以及程序更高的权限,所以,我们可以使用它对Android设备进行最基本的调试操作。 而在小天才电话手表上启用它,您只需要这么做: - 打开拨号盘; - 输入; - 点按打开adb调试选项。 其次是电脑上的Android SDK Platform-Tools的安装,此工具是 Android SDK 的组件。 它包括与 Android 平台交互的工具,主要由和构成,如果您接触过Android开发,必然会使用到它,因为它包含在Android Studio等IDE中,当然,您可以独立下载,在下方选择对应的版本即可: - Download SDK Platform...
已经博主授权,源码转载自 https://pan.quark.cn/s/b24469074755 SmartDNS English SmartDNS SmartDNS 是一个运行在本地的 DNS 服务器,它接受来自本地客户端的 DNS 查询请求,然后从多个上游 DNS 服务器获取 DNS 查询结果,并将访问速度最快的结果返回给客户端,以此提高网络访问速度。 SmartDNS 同时支持指定特定域名 IP 地址,并高性匹配,可达到过滤广告的效果; 支持DOT,DOH,DOQ,DOH3,更好的保护隐私。 与 DNSmasq 的 all-servers 不同,SmartDNS 返回的是访问速度最快的解析结果。 支持树莓派、OpenWrt、华硕路由器原生固件和 Windows 系统等。 使用指导 SmartDNS官网:https://pymumu..io/smartdns 软件效果展示 仪表盘 SmartDNS-WebUI 速度对比 阿里 DNS 使用阿里 DNS 查询百度IP,并检测结果。 SmartDNS 使用 SmartDNS 查询百度 IP,并检测结果。 从对比看出,SmartDNS 找到了访问 最快的 IP 地址,比阿里 DNS 速度快了 5 倍。 特性 多虚拟DNS服务器 支持多个虚拟DNS服务器,不同虚拟DNS服务器不同的端口,规则,客户端。 多 DNS 上游服务器 支持配置多个上游 DNS 服务器,并同时进行查询,即使其中有 DNS 服务器异常,也不会影响查询。 支持每个客户端独立控制 支持基于MAC,IP地址控制客户端使用不同查询规则,可实现家长控制等功能。 返回最快 IP 地址 支持从域名所属 IP 地址列表中查找到访问速度最快的 IP 地址,并返回给客户端,提高...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值