当前位置: 首页 > news >正文

东莞阳光网站网站后台灰色

东莞阳光网站,网站后台灰色,网络科技工作室起名,南平武夷山网站建设B-最少剩几个?_牛客小白月赛98 (nowcoder.com) 思路 奇数偶数 奇数;奇数*偶数 奇数 所以在既有奇数又有偶数时,两者结合可以同时删除 先分别统计奇数,偶数个数 若偶个数大于奇个数,答案是偶个数-奇个数 若奇个数…

B-最少剩几个?_牛客小白月赛98 (nowcoder.com)

思路

奇数+偶数 = 奇数;奇数*偶数 = 奇数

所以在既有奇数又有偶数时,两者结合可以同时删除

先分别统计奇数,偶数个数

若偶个数大于奇个数,答案是偶个数-奇个数

若奇个数大于偶个数,奇数个数减去偶个数再对2取模

ac代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)int main()
{IOS;int n,ans;int ji=0,ou=0;cin>>n;vector<ll>a(n);for(int i=0;i<n;i++) {cin>>a[i];if(a[i] & 1) ji++;else ou++; }if(ou>ji)  ans=ou-ji;else{if((ji-ou)%2) ans=1;else ans=0;}cout<<ans<<endl;   return 0;
}

C-两个函数_牛客小白月赛98 (nowcoder.com)

(超时问题如何解决)

初始代码(超时)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)int main()
{IOS;ll q,a,x;cin>>q;for(int i=0;i<q;i++){ll ans=0;cin>>a>>x;if(x==1) ans=(a*x)%998244353;else{for(int i=1;i<x;i++){ans+=(a*(a%998244353*i)%998244353)%998244353;ans%=998244353;					}}ans%=998244353;cout<<ans<<endl;}return 0;
}
解决思路

1.  快速幂

时间复杂度是 O(log n),相比于直接进行指数运算,大大提高了计算效率

快速幂代码

int FastPow(int a,int x,int mod)
{int ans = 1;a%=mod;while(x){if(x&1) ans=(ans*a)%mod;a= (a*a)%mod;x>>=1;}return ans;
}

2.  递推式

因为是求和过程,可以用递推式

ac代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
ll mod=998244353;int main()
{IOS;ll q,a,x;cin>>q;for(int i=0;i<q;i++){ll ans=0;cin>>a>>x;if(x==1) ans=a%mod;else {a = a*a %mod;ans=(x-1)*x/2 %mod *a %mod;}cout<<ans<<endl;}return 0;
}

D-切割 01 串 2.0_牛客小白月赛98 (nowcoder.com)

思路:

1.  前缀和

        记录在索引的每一个位置处之前,0或1的个数

2.dp

        dp[i][j] 表示考虑前 i 个字符时,最多可以进行多少次切割;对于每个长度 len,遍历所有可能的切割起点 l,使得 l + len - 1 不超过序列的长度;对于每个起点 l,计算可能的切割终点 r;

   对于每个起点 l 和终点 r,遍历所有可能的切割分割点 k,使得 k 在 l 和 r 之间;

动态规划过程的关键在于,通过递归地考虑所有可能的切割方式,并使用前缀和数组来快速计算分割点 k 两侧的子串中0和1的累计数量。通过这种方式,算法能够高效地找到满足条件的切割次数的最大值

代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)using namespace std;/*
算法:区间DP + 前缀和 O(N*N*N)
数据结构:s0,s1前缀和数组 + 二维dp[l][r]
*/const int N = 510;int s0[N], s1[N];
int dp[N][N];void solve() {int n, L, R;string s;cin >> n >> L >> R >> s;s = " " + s;for (int i = 1; i <= n; i ++ )s0[i] = s0[i - 1] + (s[i] == '0'),s1[i] = s1[i - 1] + (s[i] == '1');for (int len = 1; len <= n; len ++ )for (int l = 1; l <= n; l ++ ){int r = l + len - 1;if (r > n) break;for (int k = l; k < r; k ++ ){int c0 = s0[k] - s0[l - 1];int c1 = s1[r] - s1[k];if (L <= abs(c0 - c1) && abs(c0 - c1) <= R) dp[l][r] = max(dp[l][r], 1 + dp[l][k] + dp[k + 1][r]);}}cout << dp[1][n] << '\n';
}signed main() {IOS;int t = 1;
//    cin >> t;while (t--) {solve();}return 0;
}

http://www.yayakq.cn/news/70878/

相关文章:

  • 商务网站建设的一般流程是什么如何做文献ppt模板下载网站
  • 网站开发好不好大荔县住房和城市建设局网站
  • 南京的网站建设公司哪家好网站推广方法有几种
  • 杭州如何设计网站首页现在做推广有什么好的方法
  • 甘肃建设项目审批权限网站洪梅镇网站建设
  • seo搜索引擎优化费用seo优
  • 孝感房产网站建设聊天代理分销系统
  • dz网站模板 首页显示内容银川网站建设一条龙服务
  • 网站备案 seo标小智在线logo免费设计
  • 手机把网站做成软件网页设计入门教程电子书下载
  • 国外 素材 网站网站推广软件下拉管家
  • 徐闻网站开发公司网络营销策划方案内容
  • 做中小型网站最好的架构wordpress 手册主题
  • 做画册找什么网站nginx 做网站
  • 绍兴专业做网站网站备案号的区别
  • 中交通力建设股份有限公司网站表白网页生成
  • 成都商城网站建设国外专门做旅游攻略的网站
  • 企业网站建设对网络营销有哪些影响二级注册建造师信息查询官网入口
  • 网站优化策划方案电子商务网站建设与管理实验总结
  • 做网站平台公司高品质的网站开发
  • 盐城网站建设制作方案网站开发与维护前景
  • 校园网站怎么做HTML广东深圳房价
  • 怎么在网上找做网站的客户宜兴市的城乡建设管理局网站
  • 申请备案网站首页陕西网站建设的内容
  • 为什么网站建设还要续费wordpress页面调用子页面
  • 公司网站建设记哪个科目北大青鸟学费一览表
  • 如何做自己的个人网站男的做直播哪个网站好
  • 电子购物网站建设视频建设工程信息发布网站
  • 网站开发流程属于制作与开发wordpress建设
  • 阿里云服务器创建多个网站深圳官方网站设计