ZOJ - 3829 Known Notation(模拟+贪心)

http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3829

给定一个字符串(只包含数字和星号)可以在字符串的任意位置添加一个数字,还可以交换任意两个字符,问需要多少步能得到一个合法后缀表达式.

如果数字<星号+1 那么必须要添加数字,那么肯定是添加在字符串前面是最优的,然后从头到尾扫描整个串,如果遇到星号并且前面出现的数字>=2

数字减1,否则就要从后往前找第一个非*的数字然后与星号交换.

注意全为数字的情况,和处理完后字符串末尾不为*就要加上*号.

 1 #include <cstdio>
 2 #include <string>
 3 #include <iostream>
 4 using namespace std;
 5 int main()
 6 {
 7     //freopen("a.txt","r",stdin);
 8     int t,n;
 9     string s;
10     scanf("%d",&t);
11     while(t--)
12     {
13         cin>>s;
14         n=s.length();
15         int num1=0,num2=0;
16         for(int i=0;i<n;i++)
17         {
18             if(s[i]=='*') num1++;
19             else num2++;
20         }
21         //cout<<num1<<num2<<endl;
22         if(num2==n) {printf("0\n");continue;}
23         int ans=0;
24         if(num2<=num1)
25         {
26             ans=num1+1-num2;
27             for(int i=0;i<ans;i++)
28             s="1"+s;
29         }
30         num1=0;
31         n=s.length();
32         for(int i=0;i<n;i++)
33         {
34             if(s[i]=='*')
35             {
36                 if(num1>=2) num1--;
37                 else
38                 {
39                     for(int j=n-1;j>=0;j--)
40                     {
41                         if(s[j]!='*')
42                         {
43                             s[i]='1';s[j]='*';
44                             break;
45                         }
46                     }
47                     ans++;
48                     num1++;
49                 }
50             }
51             else num1++;
52         }
53         if(s[n-1]!='*')
54         {
55            // cout<<s[n-1]<<endl;
56             ans++;
57         }
58         printf("%d\n",ans);
59     }
60     return 0;
61 }

转载于:https://www.cnblogs.com/nowandforever/p/4592403.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值