You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
shudu/README.md

310 lines
4.1 KiB

数独实验第1题
#include<stdio.h>
int main()
{
int board[9][9]={{5,3,4,6,7,8,9,1,2},
{6,7,2,1,9,5,3,4,8},
{1,9,8,3,4,2,5,6,7},
{8,5,9,7,6,1,4,2,3},
{4,2,6,8,5,3,7,9,1},
{7,1,3,9,2,4,8,5,6},
{9,6,1,5,3,7,2,8,4},
{2,8,7,4,1,9,6,3,5},
{3,4,5,2,8,6,1,7,9}};
int i,j;
for(i=0;i<9;i++)
{
for(j=0;j<9;j++)
{
printf("%-2d",board[i][j]);
if(j==8)
{
printf("\n");
}
if(j==2||j==5)
{
printf(" | ");
}
}
if(i==2||i==5||i==8)
{
printf("-----------------------\n");
}
}
}
数独第2
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
int main()
{
srand(time(NULL));
int a[9][9]={0};
int b[3][3]={0};
int c[9]={0};
int d[9]={0};
int e[9]={0};
int i=0;
for(i=0;i<9;i++)
{
c[i]=i+1;
}
for(i=0;i<9;i++)
{
int j=rand()%9;
int temp=c[i];
c[i]=c[j];
c[j]=temp;
}
for(i=0;i<9;i++)
{
d[i]=i+1;
}
for(int i=0;i<9;i++)
{
int j=rand()%9;
int temp=d[i];
d[i]=d[j];
d[j]=temp;
}
for(i=0;i<9;i++)
{
e[i]=i+1;
}
for(i=0;i<9;i++)
{
int j=rand()%9;
int temp=d[i];
e[i]=e[j];
e[j]=temp;
}
for(i=0;i<9;i++)
{
printf("%d",c[i]);
}
printf("\n");
for(i=0;i<9;i++)
{
printf("%d",d[i]);
}
printf("\n");
for(i=0;i<9;i++)
{
printf("%d",e[i]);
}
int p=0;
for(i=0;i<3;i++)
{
int j;
for(j=0;j<3;j++)
{
a[i][c[p]-1]=d[p];
p++;
}
}
p=0;
for(i=3;i<6;i++)
{
int j;
for(j=0;j<3;j++)
{
a[i][d[p]-1]=e[p];
p++;
}
}
p=0;
for(i=6;i<9;i++)
{
int j;
for(j=0;j<3;j++)
{
a[i][e[p]-1]=c[p];
p++;
}
}
for(i=0;i<9;i++)
{
int j;
for(j=0;j<9;j++)
{
printf("%d",a[i][j]);
}
printf("\n");
}
return 0;
}
数独实验第3
#include<stdio.h>
int main()
{
int board0[9][9] = { {5, 3, 0, 0, 7, 0, 0, 0, 0},
{6, 0, 0, 1, 9, 5, 0, 0, 0},
{0, 9, 8, 0, 0, 0, 0, 6, 0},
{8, 0, 0, 0, 6, 0, 0, 0, 3},
{4, 0, 0, 8, 0, 3, 0, 0, 1},
{7, 0, 0, 0, 2, 0, 0, 0, 6},
{0, 6, 0, 0, 0, 0, 2, 8, 0},
{0, 0, 0, 4, 1, 9, 0, 0, 5},
{0, 0, 0, 0, 8, 0, 0, 7, 9} };
int i, j,x,y,m=0;
printf("The original Sudoku matrix:\n ");
for (i = 0; i < 9; i++)
{
for (j = 0; j < 9; j++)
{
printf("%-2d", board0[i][j]);
if (j == 8)
{
printf("\n");
}
}
}
for (i = 0; i < 9; i++)
{
for (j = 0; j < 9; j++)
{
if (board0[i][j] != 0)
{
x = i + 1;
y = j + 1;
for (; y < 9;y++)
{
if (board0[i][j] != board0[i][y])
{
m = m;
}
else
{
m++;
}
}
for (; x < 9; x++)
{
if (board0[i][j] != board0[x][j])
{
m = m;
}
else
{
m++;
}
}
}
else
{
continue;
}
}
}
if (m == 0)
{
printf("True:Valid initial Sudoku matrix!\n");
}
else
{
printf("False:Invalid initial Sudoku matrix!\n");
}
}
数独实验第4题(部分)
#include <stdio.h>
#include <stdlib.h>
#define N 3
#define M 9
#include<stdio.h>
int x[M][M]={{8, 3, 0, 0, 7, 0, 0, 0, 0},
{6, 0, 0, 1, 9, 5, 0, 0, 0},
{0, 9, 8, 0, 0, 0, 0, 6, 0},
{8, 0, 0, 0, 6, 0, 0, 0, 3},
{4, 0, 0, 8, 0, 3, 0, 0, 1},
{7, 0, 0, 0, 2, 0, 0, 0, 6},
{0, 6, 0, 0, 0, 0, 2, 8, 0},
{0, 0, 0, 4, 1, 9, 0, 0, 5},
{0, 0, 0, 0, 8, 0, 0, 7, 9}};
void Solve(int r, int c);
int checkedbox(int r);
int checked(int r, int c, int num);
int* getData(int r, int c,int *data);
void show(void);
void Solve(int r, int c)
{
int i;
if (r == M) {
show();
return;
}
if (c == 0 && (r == N || r == N*2)) {
if (checkedbox(r) == 0) {
return;
}
}
if (c == M) {
Solve(r+1, 0);
return;
}
if (x[r][c] == 0) {
for (i = 1; i <= M; i++) {
if (checked(r,c,i) == 1) {
x[r][c]=i;
Solve(r, c+1);
x[r][c]=0;
}
}
}
else{
Solve(r, c+1);
}
}
int checkedbox(int r) {
int i,j,c;
int *data = malloc(sizeof(int)*M);
for (c = 0; c < M; c+=N) {
data = getData(r,c,data);
for(i = 0; i < M-1 ; i++) {
for(j = i+1 ; j < M ; j++) {
if(data[i] == data[j]) {
return 0;
}
}
}
}
free(data);
return 1;
}
int* getData(int r, int c,int *data){
int i,j,k = 0;
for (i = r-N; i < r ; i++) {
for(j = c; j < c+N ; j++){
data[k++] = x[i][j];
}
}
return data;
}
int checked(int r, int c, int num) {
int j = 0,flag = 1;
for (j = 0; j < M; j++) {
if (x[j][c]==num || x[r][j]==num) {
flag = 0;
}
}
return flag;
}
void show(void) {
int i,j;
for (i = 0; i < M; i++) {
for (j = 0; j < M; j++) {
printf("%d ",x[i][j]);
}
printf("\n");
}
printf("\n");
}
int main(void)
{
Solve(0,0);
return 0;
}