zoukankan      html  css  js  c++  java
  • luogu p1037 产生数双做法

    题目见洛谷

    eee

    //图论做法+高精
    #include <iostream>
    #include <string>
    using namespace std;
    string str;
    int k,vis[10][10],f[10],num[101];
    inline void floyd() {  //弗洛伊德
      for (int k = 0;k <= 9;k++)
        for (int i = 0;i <= 9;i++)
          for (int j = 0;j <= 9;j++) vis[i][j] = vis[i][j] || (vis[i][k] && vis[k][j]);
    }
    int main (){
      ios::sync_with_stdio(false);
      cin >> str >> k;
      while (k--) {
        int a,b;
        cin >> a >> b;
        vis[a][b] = true;  //a可以变成b
      }
      for (int i = 0;i <= 9;i++) vis[i][i] = true;  //自己可以变成自己
      floyd();
      for (int i = 0;i <= 9;i++)
        for (int j = 0;j <= 9;j++)
          if (vis[i][j]) f[i]++;  //求出i可以变成多少种数字
      int len = 2; num[1] = 1;
      
      
      for (int i = 0;i < (int)str.length();i++) {  //高精度
        for (int j = 1;j <= 100;j++) num[j] *= f[str[i]-'0'];
        for (int j = 1;j <= 100;j++)
          if (num[j] >= 10) {  //进位
            num[j+1] += num[j]/10;
            num[j] %= 10;
          }
        while (num[len]) len++;  //求出长度
      }
      for (int i = len-1;i >= 1;i--) cout << num[i];  //输出
      return 0;
    }
    inline void dfs(int x)
    {
    	vis[x]=1;//将搜到的做标记 
    	ans++;
    	for(int i=1;i<=k;i++)
    		if(a[i]==x&&!vis[b[i]])
    		dfs(b[i]);//如果符合且未被搜索
    }
    dfs原理类似但好像更快一点
    

      

    对每一位数字进行DFS

    每搜索到一个数字计数器加一。

    最后根据分步计算原理,将每位数可扩展的数进行相乘输出即可

  • 相关阅读:
    简单取色器
    第一部分实现功能:使用一个TabControl和一个Memo和TDictionary类实现文本临时存储
    功能设计笔记概要
    NFC与RFID简介
    【JAVA设计模式-第四课】观察者模式-屌丝求职记+新闻订阅
    「学习笔记」左偏树
    「SP122」STEVE
    「学习笔记」 FHQ Treap
    「整理」同余
    「目录」数论
  • 原文地址:https://www.cnblogs.com/shikeyu/p/12833071.html
Copyright © 2011-2022 走看看