#include <stdio.h> #include <stdlib.h> // 第一題 // 找出N個數的第k個最大者 // 方法1:排序(冒泡),降序找出第k個值 // 方法2:選前k個點進行降序排序,後面的數進行比較, // 若是數比第k個數小則忽略, 複雜度低於方法1 #define TYPE int #define TESTBUBLESORT 1 #define TESTBLOCKCOMPARE 1 #define TESTWORDPUZZLE 1 int findk_bublesort(TYPE *pData, int N, int k); int findk_blockcompare(TYPE *pData, int N, int k); // 缺點修改了原數據 // 第二題 // wordpuzzle猜字謎遊戲,在三個方向上找單詞 // dirction = 0 水平方向 從左至右 // dirction = 1............右..左 // ...........2............上..下 // ...........3............下..上 // ...........4............正對角線-> // ...........5....................<- // ...........6............負對角線<- // ...........7....................-> // pData字謎 // pattern:欲猜的單詞 int wordpuzzle(char *pData, char *pattern, int row, int col, int driction); int my_strlen(char *s); // 獲取字符串的長度 void my_strcat(char *s, char *t); // 鏈接字符串 void my_strcpy(char *s, char *t); // 複製字符串 // Test Model int main() { printf("Hello world!\n"); int N = 10000; int k = N / 2; TYPE *pTestData = (TYPE *)malloc(sizeof(TYPE) * N); int i; for (i = 0; i < N; ++i) pTestData[i] = i; #ifdef TESTBUBLESORT // printf("the k = %d in N is %d\n", k, findk_bublesort(pTestData, N, k)); #endif #ifdef TESTBLOCKCOMPARE printf("the k = %d in N is %d\n", k, findk_blockcompare(pTestData, N, k)); #endif // for (i = 0; i < N; ++i) // printf("%d ", pTestData[i]); // printf("\n"); free(pTestData); #ifdef TESTWORDPUZZLE int row = 4; int col = 4; char *WorldModle = (char *)malloc(sizeof(char) * row * col); char *a1 = "this"; char *a2 = "wats"; char *a3 = "oahg"; char *a4 = "fght"; my_strcpy(WorldModle, a1); my_strcat(WorldModle, a2); my_strcat(WorldModle, a3); my_strcat(WorldModle, a4); char *pattern = "that"; int np = my_strlen(pattern); if (np > row || np > col) { fputs("the pattern size is bigger!", stderr); return -1; } for (i = 0; i < 8; ++i) { if (wordpuzzle(WorldModle, pattern, row, col, i)) { printf("find word:[%s] at dirction [%d] of wordwidget\n", pattern, i); break; } } #endif return 0; } void my_strcpy(char *s, char *t) { while (*s++ = *t++) ; } void my_strcat(char *s, char *t) { while(*s) { ++s; } my_strcpy(s, t); } int findk_bublesort(TYPE *pData, int N, int k) { // 對數據進行冒泡排序 降序 int i, j; for (i = 0; i < N; ++i) { for (j = i + 1; j < N; ++j) { if (pData[i] < pData[j]) { TYPE temp; temp = pData[i]; pData[i] = pData[j]; pData[j] = temp; } } } return pData[k - 1]; } int findk_blockcompare(TYPE *pData, int N, int k) { // 先讀入前k個數進行降序排列,而後與後面的數比較 // 前k個數進行降序排列 int i, j, z; for (i = 0; i < k; ++i) { for (j = i + 1; j < k; ++j) { if (pData[i] < pData[j]) { TYPE temp; temp = pData[i]; pData[i] = pData[j]; pData[j] = temp; } } } // 與後面的數與前k個數進行比較 for (i = k; i < N; ++i) { for (j = 0; j < k; ++j) { if (pData[j] <= pData[i]) { // 大於k個數中的一個 插入新元素 for (z = k - 2; z >= j; --z) pData[z + 1] = pData[z]; // 右移元素 pData[j] = pData[i]; // 插入新元素 break; } } } return pData[k - 1]; } int wordpuzzle(char *pData, char *pattern, int row, int col, int driction) { int result = 0; int i, j; int np; int k = 0; switch (driction) { case 0: // 從水平方向從左至右找 for (i = 0; i < row; ++i) { for (j = 0; j < col; ++j) { if (pData[i * col + j] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } k = 0; } break; case 1: // 從水平方向上從右至左找 for (i = 0; i < row; ++i) { for (j = col - 1; j >= 0; --j, --np) { if (pData[i * col + j] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } k = 0; } break; case 2: // 按列從上往下找 for (i = 0; i < col; ++i) { for (j = 0; j < row; ++j) { if (pData[j * row + i] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } k = 0; } break; case 3: // 按列從下往上找 for (i = 0; i < col; ++i) { for (j = row - 1; j >= 0; --j) { if (pData[j * row + i] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } k = 0; } break; case 4: // 按正對角線從左到右 for (i = 0; i < row; ++i) { for (j = 0; j < col; ++j) { if (i == j) { if (pData[i * row + j] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } } } k = 0; break; case 5: // 按正對角線從右到左 for (i = row - 1; i >= 0; --i) { for (j = col - 1; j >= 0; --j) { if (i == j) { if (pData[i * row + j] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } } } k = 0; break; case 6: // 按負對角線從右到左 for (i = col - 1; i >= 0; --i) { for (j = 0; j < row ; --j) { if (i + j == col - 1) { if (pData[i * row + j] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } } } k = 0; break; case 7: // 從負對角線從左到右 for (i = row - 1; i >= 0; --i) { for (j = 0; j < col; ++j) { if (i + j == row - 1) { if (pData[i * row + j] == pattern[k]) { k++; } if (pattern[k] == '\0') result = 1; } } } k = 0; break; default: break; } return result; } int my_strlen(char *s) { int n = 0; while (*s++) ++n; return n; }