杰拉斯的博客
[ACM_NYOJ_19]擅长排列的小明
杰拉斯 | 时间:2013-05-07, Tue | 19,757 views编程算法
擅长排列的小明
时间限制:1000 ms | 内存限制:65535 KB
描述
小明十分聪明,而且十分擅长排列计算。比如给小明一个数字5,他能立刻给出1-5按字典序的全排列,如果你想为难他,在这5个数字中选出几个数字让他继续全排列,那么你就错了,他同样的很擅长。现在需要你写一个程序来验证擅长排列的小明到底对不对。
输入
第一行输入整数N(1<N<10)表示多少组测试数据,
每组测试数据第一行两个整数 n m (1<n<9,0<m<=n)
输出
在1-n中选取m个字符进行全排列,按字典序全部输出,每种排列占一行,每组数据间不需分界。如样例
样例输入
2 3 1 4 2
样例输出
1 2 3 12 13 14 21 23 24 31 32 34 41 42 43
[ACM_NYOJ_32]组合数
杰拉斯 | 时间:2013-05-05, Sun | 17,236 views编程算法
组合数
时间限制:3000 ms | 内存限制:65535 KB
描述
找出从自然数1、2、... 、n(0<n<10)中任取r(0<r<=n)个数的所有组合。
输入
输入n、r。
输出
按特定顺序输出所有组合。
特定顺序:每一个组合中的值从大到小排列,组合之间按逆字典序排列。
样例输入
5 3
样例输出
543 542 541 532 531 521 432 431 421 321
经典回溯算法问题:九宫格
杰拉斯 | 时间:2012-12-18, Tue | 22,522 views编程算法
九宫格是在81个格子中,要满足以下条件:(1)每个横行和竖列中的9个格子都包含数字1至9,不重复;(2)每个黑色粗实线围住的9个格子都包含数字1至9,不重复。如下表所示:
7 6 1 9 3 4 8 2 5 3 5 4 6 2 8 1 9 7 9 2 8 1 5 7 6 3 4 2 1 9 5 4 6 3 7 8 4 8 3 2 7 9 5 1 6 5 7 6 3 8 1 9 4 2 1 9 5 7 6 2 4 8 3 8 3 2 4 9 5 7 6 1 6 4 7 8 1 3 2 5 9
要求找出给定数字的九宫格。
【输入形式】
输入9行9列81个数字,其中0表示要填的数字。
【输出形式】
输出满足条件的九宫格。
【输入样例】
0 6 1 0 3 0 0 2 0 0 5 0 0 0 8 1 0 7 0 0 0 0 0 7 0 3 4 0 0 9 0 0 6 0 7 8 0 0 3 2 0 9 5 0 0 5 7 0 3 0 0 9 0 0 1 9 0 7 0 0 0 0 0 8 0 2 4 0 0 0 6 0 0 4 0 0 1 0 2 5 0
【输出样例】
7 6 1 9 3 4 8 2 5 3 5 4 6 2 8 1 9 7 9 2 8 1 5 7 6 3 4 2 1 9 5 4 6 3 7 8 4 8 3 2 7 9 5 1 6 5 7 6 3 8 1 9 4 2 1 9 5 7 6 2 4 8 3 8 3 2 4 9 5 7 6 1 6 4 7 8 1 3 2 5 9
代码及思路如下:
#include<stdio.h> bool canFill(int a[9][9], int k, int n){ int i, j, row = k / 9, col = k % 9; for(i = 0; i < 9; ++i){ if(a[i][col] == n){ return false; } } for(j = 0; j < 9; ++j){ if(a[row][j] == n){ return false; } } for(i = row - row % 3; i < row - row % 3 + 3; ++i){ for(j = col - col % 3; j < col - col % 3 + 3; ++j){ if(a[i][j] == n){ return false; } } } return true; } void fill(int a[9][9], int k = 0){ int i, j; if(k == 81){ for(i = 0; i < 9; ++i){ for(j = 0; j < 9; ++j){ printf("%d ", a[i][j]); } printf("\n"); } return; } int row = k / 9, col = k % 9; if(a[row][col] == 0){ for(i = 1; i <= 9; ++i){ if(canFill(a, k, i)){ a[row][col] = i; fill(a, k + 1); a[row][col] = 0; } } }else{ fill(a, k + 1); } } int main(){ int i, j, a[9][9]; for(i = 0; i < 9; ++i){ for(j = 0; j < 9; ++j){ scanf("%d", &a[i][j]); } } fill(a); return 0; }
2013年5月4日3点温习重写代码如下:
#include<stdio.h> int square[9][9]; int isEnabled(int k, int num){ int row = k / 9; int col = k % 9; for(int i = 0; i < 9; ++i){ if(square[row][i] == num || square[i][col] == num){ return false; } } int m = row - row % 3; int n = col - col % 3; for(int i = m; i < m + 3; ++i){ for(int j = n; j < n + 3; ++j){ if(square[i][j] == num){ return false; } } } return true; } void fill(int k = 0){ int row = k / 9; int col = k % 9; if(k >= 81){ for(int i = 0; i < 9; ++i){ for(int j = 0; j < 9; ++j){ printf("%d ", square[i][j]); } printf("\n"); } return; } if(square[row][col] > 0){ fill(k + 1); return; } for(int i = 1; i <= 9; ++i){ if(isEnabled(k, i)){ square[row][col] = i; fill(k + 1); square[row][col] = 0; } } } int main(){ for(int i = 0; i < 9; ++i){ for(int j = 0; j < 9; ++j){ scanf("%d", &square[i][j]); } } fill(); return 0; }