首页 > 其他分享 >2024初三集训模拟测试4

2024初三集训模拟测试4

时间:2024-02-22 17:46:23浏览次数:32  
标签:boy int up 2024 -- ans 初三 集训 模拟

打了一场模拟赛

又没命了

2024初三集训模拟测试4

题目难度 T4 \(\le\) T2 \(\le\) T3 \(\le\) T1

T1 打赌

非常好题目,使我骰子旋转

定义三个变量记录当前状态:上,前,左

横着旋转,四个一循环, \(ans\) 直接加 $ 14 $

(模拟模拟模拟模拟) 模拟一下就可以

  #include <bits/stdc++.h>
  using namespace std;
  int n,m;
  long long ans=0;
  int main(){
      int up=1,left=4,front=2,t;
      freopen("pogodak.in","r",stdin);
      freopen("pogodak.out","w",stdout);
      cin>>m>>n;
      int cnt=n%4;
      if(cnt){

      for(int i=1;i<=m;i++){
          // cout<<"A";
          ans+=(n/4)*14;
          ans+=up;
          for(int j=1;j<cnt;j++){
              t=left;
              left=7-up;
              up=t;
              ans+=up;
          }
          t=up;
          up=7-front;
          front=t;
          i++;
          if(i>m)break;
          ans+=(n/4)*14;
          ans+=up;
          for(int j=cnt-1;j>=1;j--){
              t=left;
              left=up;
              up=7-t;
              ans+=up;
          }
          t=up;
          up=7-front;
          front=t;
      }
      cout<<ans;
      }
      else{
          cout<<n*14*m/4;
      }
  }

我在这道题上卡了两个小时,结果最后没过样例,还有 \(80 pts\)

$ \color {white} sb骰子怎么这么能转,模拟吐了 $

T2 舞会

额 鉴定为非触

诶,怎么会有人高达 $ -180 cm$ (蚌

先排序,再双指针跑一下就行了


  #include <bits/stdc++.h>
  using namespace std;
  int boy[200000],girl[200000],ans;
  bool cmp(int a,int b){
      return a>b;
  }
  bool check(int a,int b){
      if(a<b)swap(a,b);
      if(a>0&&b<0&&a+b<0)
          return 1;
      return 0;
  }
  int main(){
      int n;
      freopen("party.in","r",stdin);
      freopen("party.out","w",stdout);
      cin>>n;
      for(int i=1;i<=n;i++){
          cin>>boy[i];
      }
      for(int i=1;i<=n;i++){
          cin>>girl[i];
      }
      sort(boy+1,boy+n+1);
      sort(girl+1,girl+n+1,cmp);
      int end_l=1,end_r=1;
      for(int i=1;i<=n;i++){
          if(boy[i]>0){
              end_l=i-1;
              break;
          }
          end_l=i;
      }
      for(int i=1;i<=n;i++){
          if(girl[i]<0){
              end_r=i-1;
              break;
          }
          end_r=i;
      }
      // cout<<end_l<<" "<<end_r<<endl;
      int l=1,r=1;
      while(l<=end_l&&r<=end_r){
          if(check(boy[l],girl[r])){
              ans++,l++,r++;
              continue;
          }
          r++;
      }
      l=n;r=n;
      while(l>end_l&&r>end_r){
          if(check(boy[l],girl[r])){
              ans++,l--,r--;
              continue;
          }
          l--;
      }
      cout<<ans<<endl;
  }

T3最小生成树

根据画图和打表可得此题求

\[\sum_{i=1}^{n} \varphi (i) \]

不会线性筛,那就现学

  #include <bits/stdc++.h>
  using namespace std;
  #define int long long
  const int p=100000007;
  int vis[100000],prime[100000],phi[100000],ans=1,n,cnt;
  void euler(int n){
      memset(vis,0,sizeof vis);
      phi[1]=1;
      for(int i=2;i<=n;i++){
          if(vis[i]==0){
              prime[++cnt]=i;
              phi[i]=i-1;
          }
          for(int j=1;j<=cnt && i*prime[j]<=n ;j++){
              vis[i*prime[j]]=1;
              if(i%prime[j]==0)
              {
                  phi[i*prime[j]]=phi[i]*prime[j];
                  break;
              }else  
                  phi[i*prime[j]]=phi[i]*(prime[j]-1);
          }
      }
  }
  signed main(){
      freopen("mst.in","r",stdin);
      freopen("mst.out","w",stdout);
      cin>>n;
      euler(n);
      for(int i=1;i<=n;i++){
          ans=ans*phi[i]%p;
      }
      cout<<ans;
  }

买汽水

剪枝+爆搜




  #include <bits/stdc++.h>
  using namespace std;
  int ans,n,m,w[100];
  bool dfs(int x,int worth){
      if(worth>m)return 0;
      if(x==n+1){
          if(worth==m){
              cout<<m<<endl;
              exit(0);
          }
          if(worth>ans && worth<=m)
              ans=worth;
          return 1;
      }
      if(!dfs(x+1,worth+w[x]));
          dfs(x+1,worth);
      return 1;
  }
  bool cmp(int a,int b){
      return a>b;
  }
  int main(){
      freopen ("drink.in","r",stdin);
      freopen ("drink.out","w",stdout);
      cin>>n>>m;
      for(int i=1;i<=n;i++){
          cin>>w[i];
      }
      sort(w+1,w+n+1,cmp);
      for(int i=n;i>=1;i--){
          if(w[i]>m)n--;
      }
      dfs(0,0);
      cout<<ans;
  }

标签:boy,int,up,2024,--,ans,初三,集训,模拟
From: https://www.cnblogs.com/hlyyllyyl/p/18027827

相关文章

  • 【2024.02.22】构图练习(滨田英明)
    ......
  • Jenkins CLI 任意文件读取漏洞(CVE-2024-23897)复现
    0x00漏洞简介Jenkins是一款基于JAVA开发的开源自动化服务器。Jenkins使用args4j来解析命令行输入,并支持通过HTTP、WebSocket等协议远程传入命令行参数。在args4j中,用户可以通过@字符来加载任意文件。这一特性存在安全风险,攻击者可以利用它来读取服务器上的任意文件。0x01影响......
  • 2024-02-21-物联网Shell语言(2-系统调用)
    2.系统调用2.1系统编程概述操作系统的职责:操作系统用来管理所有的资源,并将不同的设备和不同的程序关联起来Linux系统编程:在有操作系统打的环境下编程,并使用操作系统提供的系统调用及库函数,对系统资源进行访问系统编程就是为了让用户更方便的操作硬件设备,并且对硬件设备起到......
  • dp 学习笔记 (2024/2/22 - )
    计数[ARC107D]NumberofMultisets[ARC104D]MultisetMean大值域限制偏序计数[CF1295F]GoodContest[ARC104E]RandomLIS......
  • 2024初三集训模拟测试4
    2024初三集训模拟测试4\(T1\)打赌\(0pts\)\(T2\)舞会\(0pts\)\(T3\)最小生成树\(0pts\)经打表,有最小生成树的边权和为\(n-1\),构造每条边上的两端点互质即可。故\(\prod\limits_{i=1}^{n}\varphi(i)\)即为所求。点击查看代码constllp=100000007;llph......
  • 2024初三集训模拟测试4
    T1打赌简单题,模拟一下即可。T2舞会小贪心,尽量找离自己最近的防止后面的不能找。T3最小生成树显然权值和为\(n-1\),就是连互质的数,然后要求父亲小于儿子,所以欧拉函数一乘即可。T4买汽水正解是分成两组后搜索加剪枝,随机化也能过,数据很水。......
  • 2024.02《高效学习法》
     背口诀、划重点、反复温习……各种方法都试过了,可为什么学习成绩还是没有提高呢?其实,你不是不会学习,而是不知道正确的学习方法!日本学习之神DaiGo公开自己独创并长年使用、科学有效、实践性极高的学习秘籍:想象自己把学习内容输出到10岁的孩子都能听懂、不写学习目标而写你掌......
  • AutoCAD2024画圆或矩形实时预览消失了如何解决?
    最近有小伙伴问这个问题,他在使用AutoCAD绘制图形时,发现画圆或矩形实时预览没有了,如下,画图不容易定位,非常影响画图效率,十分苦恼不知道如何恢复? 正常CAD画圆(或矩形)会显示实时预览,如下:操作步骤:AutoCAD20241、打开AutoCAD2024软件,然后在命令栏输入:DRAGMODE,然后按Enter键......
  • 12.【2024初三集训模拟测试4】
    \(\Huge打了一场模拟赛,又垫底了。qwq\)2024初三集训模拟测试4\(\Huge还是垫底赛大佬。qwq\)赛时差点忘改\(freopen\),用的全是\(T1\)的文件,\(9:30\)才发现,吓\(④\)。T1打赌\(?pts\)又是\(\Huge\%\)你,打赌\(\Huge......
  • 【2024-02-09】连岳摘抄
    23:59银灯守岁未应眠,一听阳春自洒然。更祝明朝风日好,梅花满眼踏新年。                                                 ——《除夜次唐诗韵》明·吴与弼人最大的动......