Compare commits
2 commits
ec0592cb05
...
4d67a5480f
| Author | SHA1 | Date | |
|---|---|---|---|
| 4d67a5480f | |||
| 53f8c2034c |
3 changed files with 55 additions and 1 deletions
|
|
@ -155,8 +155,11 @@ enum Method {
|
||||||
#[derive(Debug, Parser)]
|
#[derive(Debug, Parser)]
|
||||||
struct Args {
|
struct Args {
|
||||||
filename: PathBuf,
|
filename: PathBuf,
|
||||||
|
#[clap(default_value = "reduction2")]
|
||||||
method: Method,
|
method: Method,
|
||||||
k: Option<u16>,
|
k: Option<u16>,
|
||||||
|
#[clap(short, long)]
|
||||||
|
reverse: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
|
@ -169,6 +172,20 @@ fn main() {
|
||||||
let r = vertex_cover(&graph, k, args.method);
|
let r = vertex_cover(&graph, k, args.method);
|
||||||
eprintln!("{}: {:?}", k, start.elapsed());
|
eprintln!("{}: {:?}", k, start.elapsed());
|
||||||
r
|
r
|
||||||
|
} else if args.reverse {
|
||||||
|
let mut k = graph.num_vertices();
|
||||||
|
let mut last_solution = None;
|
||||||
|
loop {
|
||||||
|
let start = std::time::Instant::now();
|
||||||
|
let r = vertex_cover(&graph, k, args.method);
|
||||||
|
eprintln!("{}: {:?}", k, start.elapsed());
|
||||||
|
if let Some(r) = r {
|
||||||
|
k = r.len() as u16 - 1;
|
||||||
|
last_solution = Some(r);
|
||||||
|
} else {
|
||||||
|
break last_solution;
|
||||||
|
};
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
let mut k = 0;
|
let mut k = 0;
|
||||||
loop {
|
loop {
|
||||||
|
|
|
||||||
|
|
@ -237,6 +237,8 @@ pub fn reduction2(graph: &mut Graph, k: u16) -> Option<Vec<u16>> {
|
||||||
let _ = graph.reinsert_vertices(1);
|
let _ = graph.reinsert_vertices(1);
|
||||||
|
|
||||||
r
|
r
|
||||||
|
} else if graph.is_empty() {
|
||||||
|
Some(Vec::new())
|
||||||
} else if k == 0 {
|
} else if k == 0 {
|
||||||
if graph.is_empty() {
|
if graph.is_empty() {
|
||||||
Some(Vec::new())
|
Some(Vec::new())
|
||||||
|
|
@ -343,6 +345,10 @@ pub fn reduction2(graph: &mut Graph, k: u16) -> Option<Vec<u16>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if let Some(vertex) = graph.get_vertex_with_degree_greater(3) {
|
} else if let Some(vertex) = graph.get_vertex_with_degree_greater(3) {
|
||||||
|
if k < 1 {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
|
||||||
graph.remove_vertex(vertex);
|
graph.remove_vertex(vertex);
|
||||||
|
|
||||||
match reduction2(graph, k - 1) {
|
match reduction2(graph, k - 1) {
|
||||||
|
|
@ -374,6 +380,6 @@ pub fn reduction2(graph: &mut Graph, k: u16) -> Option<Vec<u16>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
unreachable!()
|
unreachable!("{k}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
31
verzweigungsvectoren/main.py
Executable file
31
verzweigungsvectoren/main.py
Executable file
|
|
@ -0,0 +1,31 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
from numpy import roots,isreal
|
||||||
|
from itertools import combinations_with_replacement
|
||||||
|
|
||||||
|
|
||||||
|
solutions = []
|
||||||
|
|
||||||
|
s = [1, 2, 3, 4, 5, 6, 7, 8, 9]
|
||||||
|
|
||||||
|
for i in range(2, 7):
|
||||||
|
|
||||||
|
for j in combinations_with_replacement(s, i):
|
||||||
|
|
||||||
|
p = [-j.count(k) for k in range(max(j) + 1)]
|
||||||
|
p[0] = 1
|
||||||
|
|
||||||
|
|
||||||
|
r = [float(k) for k in roots(p) if isreal(k) and k > 0.0]
|
||||||
|
# print(j, max(j), p, r)
|
||||||
|
|
||||||
|
solutions.append((j, r[0]))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
solutions.sort(key=lambda e: e[1])
|
||||||
|
|
||||||
|
for s in solutions:
|
||||||
|
|
||||||
|
print(f"{s[1]}\t{s[0]}")
|
||||||
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue