AtCoder Beginner Contest 128 C - Switches Difficulty: 807
Le thème cette fois est un peu arithmétique Ruby
ruby.rb
n, m = gets.split.map(&:to_i)
k = []
1.upto(m) do |i|
  s = "0" * n
  h = gets.split.map(&:to_i)
  h.shift
  h.each do |j|
    s[j - 1] = "1"
  end
  k[i] = s.to_i(2)
end
p = gets.split.map(&:to_i)
ans = 0
0.upto(2 ** n - 1) do |i|
  f = 1
  1.upto(m) do |j|
    if (i & k[j]).to_s(2).count("1") % 2 != p[j - 1]
      f = 0
      break;
    end
  end
  ans += f
end
puts ans
Par exemple, si vous avez 10 commutateurs, préparez la chaîne «0000000000» et remplacez l'emplacement du commutateur souhaité par 1. => 0010011011
Comparez la chaîne avec toutes les combinaisons de bits (** 2 à la nième puissance **) et comparez avec les conditions d'éclairage.
bit.rb
k[i] = s.to_i(2)
 # =>Convertir une chaîne en un entier de notation binaire
if (i & k[j]).to_s(2).count("1") % 2 != p[j - 1]
 # =>Convertit un entier en chaîne de notation binaire et compte le nombre de 1
perl.pl
use v5.18; # strict say state
chomp (my ($n, $m) = split / /, <STDIN>);
my @k;
for my $i (1..$m) {
  my $s = '0' x $n;
  chomp (my @in = split / /, <STDIN>);
  shift @in;
  for my $j (0..$#in) {
    substr($s, $in[$j]-1, 1) = 1;
  }
  $k[$i] = $s;
}
chomp (my @p = split / /, <STDIN>);
my $ans = 0;
for my $i (0..2**$n-1) {
  my $s = sprintf "%0".$n."b", $i;
  my $f = 1;
  for my $j (1..$m) {
    $f = 0 if ((grep {$_ == 1} split('', ($s & $k[$j]))) % 2 != $p[$j-1]);
    last if $f == 0;
  }
  $ans += $f;
}
say $ans;
and.pl
$f = 0 if ((grep {$_ == 1} split('', ($s & $k[$j]))) % 2 != $p[$j-1]);
Dans * Ruby *, l'opération sur les bits de la chaîne de caractères provoque une erreur, mais dans * Perl *, le produit peut être calculé tel quel. Vérifiez le nombre de 1 avec grep.
** Addenda **
java.java
import java.util.*;
class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = Integer.parseInt(sc.next());
        int m = Integer.parseInt(sc.next());
        int k[] = new int[m];
        for (int i = 0; i < m; i++) {
            StringBuilder s = new StringBuilder("0000000000".substring(0, n));
            int x = Integer.parseInt(sc.next());
            for (int j = 0; j < x; j++) {
                int y = Integer.parseInt(sc.next());
                s.replace(y - 1, y, "1");
            }
            k[i] = Integer.parseInt(s.toString(), 2);
        }
        int p[] = new int[m];
        for (int i = 0; i < m; i++) {
            p[i] = Integer.parseInt(sc.next());
        }
        sc.close();
        int ans = 0;
        for (int i = 0; i < Math.pow(2, n); i++) {
            int f = 1;
            for (int j = 0; j < m; j++) {
                String bin = Integer.toBinaryString(i & k[j]);
                int c = 0;
                for (int v = 0; v < bin.length(); v++) {
                    if (bin.substring(v, v + 1).equals("1")) {
                        c++;
                    }
                }
                if (c % 2 != p[j]) {
                    f = 0;
                    break;
                }
            }
            ans += f;
        }
        System.out.println(ans);
    }
}
Comme il a été réécrit en * Java * basé sur la source * Perl *, les opérations sur les bits sont effectuées à l'aide de chaînes de caractères, mais bien sûr, vous pouvez également répondre en utilisant des opérations de décalage.
| Ruby | Perl | Java | |
|---|---|---|---|
| Longueur du code | 395 Byte | 612 Byte | 1424 Byte | 
| Temps d'exécution | 11 ms | 19 ms | 123 ms | 
| Mémoire | 3836 KB | 896 KB | 24020 KB | 
Site référencé
Recommended Posts