信息学奥赛一本通 1333:【例2-2】Blah数集 | OpenJudge NOI 3.4 2729:Blah数集

【题目链接】

ybt 1333:【例2-2】Blah数集
OpenJudge NOI 3.4 2729:Blah数集

【题目考点】

1. 队列

【解题思路】

要填入Blah数集的一共有两类数
第一类:由2x+1生成的数
第二类:由3x+1生成的数
那么开两个队列q2与q3,分别存储由2x+1和3x+1生成的数字。这两个队列中的数字一定是单调递增的。
不断比较两个队列的队首元素,出队较小的值,这样得到的数字是单调不减的。两个队列队首的数字可能相同,而集合中相同的数字只有一个,这种情况下两个队列同时出队,但升序序列中只增加1个数字。升序序列中第n个数,就是Blah数集中的第n个数。
具体做法:
先通过输入的基a生成2a+1与3a+1,分别入队到q2与q3中。此时计数为1。
这两个队列队首比较,哪个数更小,哪个数就出队。若相等,则同时出队。
将刚刚出队的数字设为a,计数增加1,并将2*a+1,3*a+1分别入队。
计数增加到n时,此时a的值就是Blah数集中第n小的数字。

【题解代码】

写法1:用数组与表达式实现队列
#include <bits/stdc++.h>
using namespace std;
#define N 1000005 
int q2[N], q3[N], a, n, h_2, t_2, h_3, t_3;//q2,q3:两个队列 h,t两个队列的头尾指针
int main()
{
    while(scanf("%d %d", &a, &n) != EOF)
    {
        h_2 = t_2 = h_3 = t_3 = 0;//清空两个队列
        int count = 1;//count计数
        q2[++t_2] = 2*a + 1;//入队
        q3[++t_3] = 3*a + 1;
        while(count < n)
        {
            if(q2[h_2+1] < q3[h_3+1])//队首比较
                a = q2[++h_2];//队列2出队
            else if(q2[h_2+1] > q3[h_3+1])
                a = q3[++h_3];//队列3出队
            else//二者相等,都出队
            {
                a = q2[++h_2];
                ++h_3;
            }
            q2[++t_2] = 2*a + 1;//入队
            q3[++t_3] = 3*a + 1;
            count++;
        }
        printf("%d\n", a);
    }
	return 0;
}
写法2:使用C++ STL
#include<bits/stdc++.h>
using namespace std;
int main()
{   
	queue<int> q2, q3;
	int a, n;
	while(cin >> a >> n)
	{
		q2 = queue<int>();//清空队列 
		q3 = queue<int>();
		for(int i = 2; i <= n; ++i)//求第i小的值,初始情况a是第1小的值 
		{
			q2.push(2*a+1);
			q3.push(3*a+1);
			if(q2.front() > q3.front())//如果3x+1队列队首更小 
			{
				a = q3.front();
				q3.pop();
			}
			else if(q2.front() < q3.front())//如果2x+1队列队首更小
			{
				a = q2.front();
				q2.pop();
			}
			else
			{
				a = q2.front();
				q2.pop();
				q3.pop();
			}
		}
		cout << a << endl;
	} 
    return 0;
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将vsftpd欢迎响应文设置为"220-Welcome to blah FTP service.\r\n 220-connect successful.\r\n 220 thank for you using.\r\n",您需要修改vsftpd的配置文件。打开vsftpd的配置文件(/etc/vsftpd.conf),找到并修改以下两行: welcome_message=Welcome to blah FTP service. ``` 将其修改为: welcome_message=220-Welcome to blah FTP service.\r\n 220-connect successful.\r\n 220 thank for you using.\r\n ``` 完成后,保存文件并重启vsftpd服务,可以使用以下命令重启: ``` sudo service vsftpd restart ``` 这样,当有用户连接到vsftpd服务器时,欢迎消息将显示为"220-Welcome to blah FTP service.\r\n 220-connect successful.\r\n 220 thank for you using.\r\n"。请确保在修改配置文件之前做好备份,并确保具有足够的权限进行修改和重启服务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [ubuntu搭建ftp和vsftpd.conf详解](https://blog.csdn.net/qq_45125250/article/details/106446141)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [在CentOS 6.3上搭建FTP服务器vsftpd](https://blog.csdn.net/weixin_42153801/article/details/116788184)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值