cf401D 状态压缩dp好题,每次把新加入集合的数字放在最后即可

/*
它可以通过重新排列数字n,
它没有任何前导零,
x除以m后的余数等于0. 每次把新加的数放在最后
dp[i][j]表示状态i下模m=j的数量
dp[i|(1<<k)][j*10+a[k]]+=dp[i][j]; */
#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll len,n,m,a[];
ll dp[<<][];
int main(){
cin>>n>>m;
while(n)a[++len]=n%,n/=;
dp[][]=;
for(int i=;i<(<<len)-;i++)
for(int j=;j<m;j++)
for(int k=;k<len;k++){
if(i&(<<k))continue;
if(i==&&a[k+]==)continue;//前导0
dp[i|(<<k)][(j*+a[k+])%m]+=dp[i][j];
}
ll cnt[]={},f[]={},ans=dp[(<<len)-][];
f[]=f[]=;
for(int i=;i<=;i++)f[i]=f[i-]*i;
for(int i=;i<=len;i++)cnt[a[i]]++;
for(int i=;i<;i++)
if(cnt[i])ans/=f[cnt[i]];
cout<<ans<<endl;
}

cf959E 思维题

#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll n,ans;
ll lowbit(ll x){return x&(-x);} int main(){
cin>>n;
ll tmp=n,cnt=;
while(tmp){
ans+=tmp/*cnt;
tmp/=,cnt*=;
}
if(n==lowbit(n)){
cout<<ans<<endl;
return ;
}
while(n){
n-=lowbit(n); ans+=lowbit(n);
}
cout<<ans<<endl;return ;
}

cf598E dp好题,就是最经典的线性dp,想通了挺简单的

/*
dp[i][j][k]在i*j的方块里吃k大小的代价
*/
#include<bits/stdc++.h>
using namespace std;
int dp[][][];
int main(){
for(int i=;i<=;i++)
for(int j=;j<=;j++)
for(int k=;k<=;k++){
if(k== || k==i*j){
dp[i][j][k]=;
continue;
}
else dp[i][j][k]=;
for (int h = ; h <= k; h++){
for (int m = ; m < j; m++)
dp[i][j][k] = min(dp[i][j][k], dp[i][m][h] + dp[i][j - m][k - h] + i*i);
for (int m = ; m < i; m++)
dp[i][j][k] = min(dp[i][j][k], dp[m][j][h] + dp[i - m][j][k - h] + j*j);
}
}
int t,n,m,k;
cin>>t;
while(t--){
cin>>n>>m>>k;
cout<<dp[n][m][k]<<endl;
}
}

cf886D 字符串乱搞+判环

#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
using namespace std; string s,ans[]; int main()
{
int i,j,n,f,x,len;
int vis[],chu[],ru[],mp[][];
while(cin>>n)
{
f=;
memset(mp,,sizeof(mp)); //字符构成的图
memset(ru,-,sizeof(ru)); //每个字符的入度
memset(chu,-,sizeof(chu)); //每个字符的出度
//在下面这个循环中,chu/ru=0则说明字符出现过,chu/ru=-1则没出现过
for(i=;i<n;i++)
{
cin>>s; //输入字符串
memset(vis,,sizeof(vis)); //用于判断每个字符串中字符出现的次数
len=s.length();
vis[s[]-'a']++; //首个字符出现次数+1
ru[s[]-'a']=; //首个字符出现过
chu[s[]-'a']=; //首个字符出现过
for(j=;j<len;j++)
{ //从第 1 个字符开始建图
int u=s[j-]-'a'; //前一字符
int v=s[j]-'a'; //当前字符
mp[u][v]=;
vis[v]++;
if(vis[v]>) f=; //如果出现次数>1,则输出 NO
ru[v]=;
chu[v]=;
}
}
int next[]; //每个字符的后继字符
memset(next,-,sizeof(next));
for(i=;i<;i++)
for(j=;j<;j++)
if(mp[i][j])
{ //如果存在边
ru[j]++; //入度+1
chu[i]++; //出度+1
next[i]=j; //记录后继
}
for(i=;i<;i++)
if(ru[i]>||chu[i]>)
{ //如果有字符的出度或入度 >1则输出 NO
f=;
break;
}
for(i=;i<;i++)
{ //判断是否有环
x=i;
memset(vis,,sizeof(vis));
while(x!=next[x])
{
if(vis[x]==)
{ //如果当前元素访问过则有环
f=;
break;
}
vis[x]=;
x=next[x];
}
}
if(n> || !f)
{
cout<<"NO"<<endl;
continue;
}
int tol=;
for(i=;i<;i++) //遍历 26个字符
if(ru[i]==)
{ //如果入度为 0,则会形成一串字符
ans[tol]='a'+i;
x=i;
while(next[x]!=-)
{ //加入后继字符
char c=next[x]+'a';
ans[tol]+=c;
x=next[x];
}
tol++;
}
sort(ans,ans+tol); //排序
for(i=;i<tol;i++) cout<<ans[i];
cout<<endl;
}
return ;
}

4.9cf自训9..的更多相关文章

  1. Java企业实训 - 01 - Java前奏

    前言: 虽然个人专攻.NET方向,不过由于个人是干教育行业的,方方面面的东西,不能说都必须精通,但肯定多少都会涉及到. 一个菜鸟学员,从啥都不会,经过一步步学习,最后到企业上手掌管一个模块甚至一个项目 ...

  2. UML基础与Rose建模实训教程

    目  录 第1章  初识UML. 1 1.1 初识UML用例图... 1 1.2 初识UML类图... 3 第2章  Rational Rose工具... 6 2.1 安装与配置Rational Ro ...

  3. <实训|第六天>偷偷让新手的Linux无限重启附linux主机名称不是随便乱改的!

    先说个事情:这几天我正在忙一个项目的设计,8月1号之前要弄出来,所以每天都要弄到很晚,可能更新就有点跟不上了,不过我如果有时间的话,我就更新,没时间的话,我会在8月1号之后统一更新出来,希望大家谅解! ...

  4. <实训|第五天>通过搭建NFS,FTP实现共享文件附Vim脚本游戏

    先说个事情:我周末是不更新这个系列教程的,不过其他内容的会更新,我周末就整理这一周的各种内容到我的微信公众号中,提供给大家! 期待已久的linux运维.oracle"培训班"终于开 ...

  5. ThoughtWorks西邮暑期特训营 -- JavaScript在线笔试题

    ThoughtWorks 公司在西邮正式开办的只教女生前端开发的女子卓越实验室已经几个月过去了,这次计划于暑期在西邮内部开展面向所有性别所有专业的前端培训. 具体官方安排请戳:ThoughtWorks ...

  6. 软件工程实训项目案例--Android移动应用开发

    实训过程 角色分工 1.项目经理:负责项目的组织实施,制定项目计划,并进行跟踪管理 2.开发人员:对项目经理及项目负责 3.需求分析员:负责系统的需求获取和分析,并协助设计人员进行系统设计 4.系统设 ...

  7. <实训|第四天>Linux下的vim你真的掌握了吗?附上ftp远程命令上传。

    期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...

  8. <实训|第三天>Linux登录界面的修改以及Richard Stallman、自由软件运动

    在写博客之前我想说两点: 承认一个错误,昨天写的实训第二天,我把redhat6.7写成了Linux6.7,感谢热心人士的指出! 昨天写的文章名字太长了,今天改善,内容感觉表述不全,希望各位谅解! 官方 ...

  9. <实训|第二天>掌握linux6.7中安装vmware、vmware安装linux发行版本以及遇到的问题最后libreoffice的安装

    期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...

随机推荐

  1. Kubernetes — Job与CronJob

    有一类作业显然不满足这样的条件,这就是“离线业务”,或者叫作 Batch Job(计算业务). 这 种业务在计算完成后就直接退出了,而此时如果你依然用 Deployment 来管理这种业务的话,就会 ...

  2. MySQL CONCAT opposite

    csv - What is the opposite of GROUP_CONCAT in MySQL? - Stack Overflowhttps://stackoverflow.com/quest ...

  3. DEVOPS 运维开发系列

    DEVOPS 运维开发系列四:ITIL事态管理流程.事态监控系统设计以及基于Devops的效率提升实践 - watermelonbig的专栏 - CSDN博客https://blog.csdn.net ...

  4. Mybatis映射文件的自动映射与手动映射问题

    Mapper XML 文件 MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会 ...

  5. Android艺术——探究Handler运行机制

    我们从开发的角度来说,Handler是Android 的消息机制的上层接口.说到Handler,大家都会说:哦,Handler这个我知道干什么的,更新UI.没错,Handler的确是用于更新UI的,具 ...

  6. Socket通信例子

    Server端 using System; using System.Collections.Generic; using System.ComponentModel; using System.Da ...

  7. 记录腾讯云中矿机病毒处理过程(重装系统了fu*k)

    刚想学学kafka,登录与服务器看看把,谁知ssh特别慢,很奇怪,我以为是我网速问题,断了wifi,换了网线,通过iterm想要ssh root@x.x.x.x,但是上不去? 就tm的很奇怪了,登录腾 ...

  8. 基于scrapy-redis的分布式爬虫

    一.介绍 1.原生的scrapy框架 原生的scrapy框架是实现不了分布式的,其原因有: 1. 因为多台机器上部署的scrapy会各自拥有各自的调度器,这样就使得多台机器无法分配start_urls ...

  9. HBase轻松入门之HBase架构图解析

    2018-12-13 2018-12-20 本篇文章旨在针对初学者以我本人现阶段所掌握的知识就HBase的架构图中各模块作一个概念科普.不对文章内容的“绝对.完全正确性”负责. 1.开胃小菜 关于HB ...

  10. OpenLayers学习笔记(九)— 限制地图显示范围

    openlayers 3 地图上限制地图显示及拖动范围,坐标系是4326转3857,中心经纬度精确到小数点后六位,减少误差 GitHub:八至 作者:狐狸家的鱼 本文链接:ol3-限制地图显示及拖动范 ...