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

购买qq空间访客的网站网络营销课程ppt

购买qq空间访客的网站,网络营销课程ppt,厂房设计,建设银行北京东四支行网站可分解的正整数 算法&#xff1a;思维 因为可以有负数 所以除了1以外的任何数都可以构造 当这个数为x构造方法为 -(x-1) -(x-2) -(x-3) ....-1 0 1...x-3 x-2 x-1 x 除了x&#xff0c;x以前的数都会被负数抵消 #include <bits/stdc.h> #define ll long long ll a…

可分解的正整数

算法:思维

因为可以有负数 所以除了1以外的任何数都可以构造

当这个数为x构造方法为

-(x-1)  -(x-2)  -(x-3) ....-1 0 1...x-3 x-2 x-1 x

除了x,x以前的数都会被负数抵消

#include <bits/stdc++.h>
#define ll long long
ll a[100005];
using namespace std;
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);ll n;cin>>n;for(int i=1;i<=n;i++){cin>>a[i];}ll ans=0;for(int i=1;i<=n;i++){if(a[i]!=1) ans++;}cout<<ans<<"\n";return 0;
}

产值调整

算法:思维 打表

当三个数相同时 不管怎么调整 结果不会发生改变,所以当三个数相同时break即可

根据模拟题目要求打表后发现,调整100次后 所有数都会变成相同的,所以break后不会使代码超时

#include <bits/stdc++.h>
#define ll long long
ll a[100005];
using namespace std;
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);ll t;cin>>t;while(t--){ll a,b,c,k;cin>>a>>b>>c>>k;for(int i=1;i<=k;i++){ll na,nb,nc;na=(b+c)/2;nb=(a+c)/2;nc=(a+b)/2;a=na;b=nb;c=nc;if(a==b and b==c) break;}cout<<a<<" "<<b<<" "<<c<<" "<<"\n";}return 0;
}

画展布置

算法:前缀和
观察计算公式 需要用到的数皆为平方 提前处理 将每个数平方后 公式将被简化为 每两个数之间的差的和 贪心的思考 使得一组数相邻两个数之间差的和最小 数组有序为最优 先排序 排序后枚举开始的位置 求当前位置到当前位置+m位置的差的和 使用前缀和预处理每个位置的前缀和查询即可。

#include <bits/stdc++.h>
#define ll long long
ll a[100005],b[100005],c[100005];
using namespace std;
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);ll n,m;cin>>n>>m;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+1+n);for(int i=1;i<n;i++){b[i]=a[i+1]*a[i+1]-a[i]*a[i];}for(int i=1;i<n;i++){c[i]=c[i-1]+b[i];}ll ans=1e18;for(int i=1;i<=n-m+1;i++){ans=min(ans,c[i+m-2]-c[i-1]);}cout<<ans<<"\n";return 0;
}

水质检测

算法:模拟

按题目要求模拟即可,唯一需要贪心的点,即为

#.
.#

的情况 从左往右判断时 若要使它们联通 最优的方案为

##
.#
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);string s[2];cin>>s[0]>>s[1];ll n=s[0].size();s[0]=" "+s[0];s[1]=" "+s[1];ll ans=0;ll l=0,r=0;for(int i=1;i<=n;i++){if((s[0][i]=='#' || s[1][i]=='#') && l==0){l=i;}if((s[0][i]=='#' || s[1][i]=='#')){r=i;}}ll cnt=-1;if(s[0][l]=='.' && s[1][l]=='#') cnt=1;if(s[1][l]=='.' && s[0][l]=='#') cnt=0;for(int i=l+1;i<=r;i++){if(s[0][i]=='.' && s[1][i]=='.'){ans++;}else if(s[0][i]=='#' && s[1][i]=='.'){if(cnt==1){cnt=-1;ans++;}else{cnt=0;}}else if(s[0][i]=='.' && s[1][i]=='#'){if(cnt==0){cnt=-1;ans++;}else{cnt=1;}}else{cnt=-1;}}cout<<ans<<"\n";return 0;
}

生产车间

算法:树形DP/树上DP

先考虑这道题 但没考虑出来 开始蹭分

于是输出根的权值获得(洛谷50%)

#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll a[1005];
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);ll n;cin>>n;ll ans=0;for(int i=1;i<=n;i++){cin>>a[i];}for(int i=1;i<n;i++) {ll o,p;cin>>o>>p;}cout<<a[1];return 0;
}

装修报价

方案1:DFS爆搜(30%分)

算法:DFS

为每两个数字之间遍历它们是否为异或。如果当前位置为异或,则提前计算,并储存它们异或后的数字序列。 然后遍历每个位置是‘+’还是‘-’并计算,加入答案。

#include <bits/stdc++.h>
#define ll long long
ll a[100005];
using namespace std;
const ll MOD = 1e9 + 7;
ll ans=0;ll n;
void dfs2(vector<ll> v){if(v.size()==1){ans+=v[0];ans%=MOD;return;}ll it=v[v.size()-1];v.pop_back();v[0]+=it;dfs2(v);v[0]-=it;v[0]-=it;dfs2(v);
}
void dfs(vector<ll> v,ll x){if(x>n) {dfs2(v);return;}v.push_back(a[x]);dfs(v,x+1);v.pop_back();if(v.size()){ll tp=v[v.size()-1];v[v.size()-1]^=a[x];dfs(v,x+1);v[v.size()-1];}
}
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>n;vector<ll> d;ll now=0;for(int i=1;i<=n;i++){cin>>a[i];now^=a[i];}dfs(d,1);cout<<ans<<"\n";return 0;
}

方案2:数学 规律 打表(100%分)

时间复杂度:O(n)

每个数字后都存在‘+’和‘-’,无论之后的数字间填写什么符号,结果都会被抵消,但从第一个位置异或到第i个位置的答案会保留(1<=i<=n)。

位置1异或到3 (1组)
0⊕2⊕5=7
位置1异或到2 (2组)位置3和它之后的都被抵消
0⊕2  +5=7
0⊕2  −5=−3
位置1 (6组) 位置2和它之后的都被抵消
0  +2⊕5=7
0  −2⊕5=−70  +2−5=−3
0  −2+5=30  +2+5=7
0  −2−5=−7

所以最后的结果为

第一个数字 1组

第一个数字异或到第二个数字 2组

第二个数字异或到第三个数字 6组

第三个数字异或到第四个数字 18组

从第n-1个数字前 每个位置的组数是后一个的三倍 依次递增求和即可

#include <bits/stdc++.h>
#define ll long long
ll a[100005];
using namespace std;
const ll MOD = 1e9 + 7;
ll ans=0;ll n;
int main() {ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>n;vector<ll> d;ll now=0;for(int i=1;i<=n;i++){cin>>a[i];now^=a[i];}ll op=2;ans+=now;now^=a[n];ll tp=0;for(int i=n-1;i>=1;i--){ans+=now*op;ans%=MOD;now^=a[i];op*=3;op%=MOD;}ans%=MOD;ans+=MOD;ans%=MOD;cout<<ans<<"\n";return 0;
}
http://www.dtcms.com/a/420372.html

相关文章:

  • Coze源码分析-资源库-编辑插件-前端源码-核心组件
  • 校园网站平台建设标准化建设考评网站
  • DKD论文阅读
  • 如何用表格做网站wordpress 插件语言
  • 项目建设管理 公司 网站德城区建设局网站
  • AI 还原历史动漫视频:从文案到剪辑全流程拆解
  • 化妆品网站设计报告学网页设计先学什么
  • 网站代码怎么优化wordpress 打赏
  • 数据中心动环监控系统解决方案:构建 “全链路感知、零秒预警、智能联动” 的运维防护体系
  • 图片放大、缩小、恢复原比例、旋转vue
  • 最大的做网站公司win7配置不能运行wordpress
  • 网站开发H5微商商城官网
  • WPS文字如何合并多个文档:两种方法
  • 1、网关分类详解:从网络层到应用层的完整网关体系
  • 益阳市住房和城乡建设局网站手机seo百度点击软件
  • 【Linux基础知识系列:第一百四十一篇】使用curl进行API交互
  • 网站建设公司如何盈利苏州网站设计哪家公司好
  • 告别 “无效坚持”,拥抱 “复利成长” | 输出型爱好如何重塑习惯
  • 阿里云这么建设网站wordpress中的联系方式
  • 做微信公众号的网站吗网站设计论文前言怎么写
  • 网站 系统 区别惠州百度seo哪里强
  • 从linux0.11再探minix文件系统设计原理
  • HTML 解析入门:用 BeautifulSoup 轻松提取网页数据
  • 合肥营销网站建设价格陕西省建设网三类人员证书查询系统
  • 优先级队列(堆)-1046.最后一块砖的重量-力扣(LeetCode)
  • 玩具网站建设方案梅州建网站
  • LLM模型的中间激活值估计
  • 网站做哪些比较赚钱方法网站策划与建设阶段的推广方法
  • 企业品牌网站建设网站背景素材
  • LlamaIndex智能体Agents开发-记忆管理