hrbust/哈理工oj 1677 一个函数【栈】【水题】

一个函数
Time Limit: 1000 MSMemory Limit: 32768 K
Total Submit: 49(38 users)Total Accepted: 39(36 users)Rating: Special Judge: No
Description

现在用一个函数来处理一个字符串(该字符串只包含x和y)。

函数的两个操作如下。

1.  在字符串中找到两个连续的字符(可以不相邻),并且第一个字符是’y’,第二个字符是’x’,然后交换它们。如果一次存在多种满足该条件的连续字符,我们就找到最靠近字符串开始位置的那组进行操作。

2.  在字符串中找到两个连续的字符(可以不相邻),并且第一个字符是’x’,第二个字符是’y’,

然后从原串中将这两个字符删除。如果一次存在多种满足该条件的连续字符,我们就找到最靠近字符串开始位置的那组进行操作。

函数的运行步骤如下:

Step1: 如果你对当前的字符串至少可以进行上面两个操作中的一个,就进入Step2,否则函数运行结束。

Step2:如果你可以进行1 操作就执行它。否则执行2操作1次,2操作结束后进入Step1.

请输出函数运行结束之后经过处理符串。

Input
输入一个字符串,保证字符串不为空且仅由’x’和’y’组成。字符串长度为1~106
Output
输出函数返回值。

保证测试数据不会让返回值为空串。

Sample Input

x

yxyxy

xxxxxxy

Sample Output

x

y

xxxxx

Author
曾卓敏 @hrbust

思路:只要有一对xy就一定能够消除

直接用一个栈来收入当前字符,如果栈顶和当前字符不同,相当于匹配出去一个y,栈顶出栈,相反入栈。

最后输出栈内元素即可:


#include<stdio.h>
#include<string.h>
#include<stack>
using namespace std;
char a[1000050];
int main()
{
    while(~scanf("%s",a))
    {
        stack<char >s;
        int n=strlen(a);
        for(int i=0;i<n;i++)
        {
            if(s.size()==0)s.push(a[i]);
            else
            {
                if(s.top()==a[i])s.push(a[i]);
                else s.pop();
            }
        }
        while(!s.empty())
        {
            printf("%c",s.top());
            s.pop();
        }
        printf("\n");
    }
}











  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
函数表(Virtual Function Table)是一张存储了虚函数地址的表格。每个包含函数的类都会有一张对应的虚函数表。该表的每一项都是一个函数的地址。这个表是属于类的,而不是属于某个具体的对象,因此一个类只需要一张虚函数表。 虚函数指针(Virtual Function Pointer),也称为vfptr,是指向虚函数表的指针。在一个对象的内存布局中,虚函数指针位于最前端。通过虚函数指针,对象可以在运行时动态地调用正确的虚函数。 具体来说,虚函数指针指向了对象所属类的虚函数表的首地址。通过这个虚函数指针,对象可以访问到自己所属类的虚函数表。而虚函数表中的每一项都是一个函数的地址,通过这个地址,对象可以调用对应的虚函数。 总结起来,虚函数表是一张存储了虚函数地址的表格,属于类而不是对象。虚函数指针是指向虚函数表的指针,位于对象的内存布局的最前端。通过虚函数指针,对象可以在运行时动态地调用正确的虚函数。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [虚函数表及虚函数表指针(看似简单,深入部分也不是很懂)](https://blog.csdn.net/fengdijiang/article/details/106737667)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [虚函数指针和虚函数表](https://blog.csdn.net/hrbust_cxl/article/details/117393978)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值