已知字符串“aabbbcddddeeffffghijklmnopqrst”編程找出出現最多的字符和次數,要求時間復雜度小于O(n^2)
/********************************************************Copyright (C), 2016-2017,FileName: main9Author: woniu201Description:求字符串中出現次數最多的字符和次數********************************************************/#include "stdafx.h"#include <stdio.h>#include <stdlib.h>#include <string.h>void search(char* pData, int len){ char counts[1024] = {0}; //存放原始數據作為為索引出現的次數 char bufMax[1024] = {0}; //用于存放出現次數最多的字符 int max = 0; //出現次數最多的字符 for (int i=0; i<len; i++) { counts[pData[i]] ++; } for (int i=0; i<1024; i++) { if (counts[i] > max) { max = counts[i]; bufMax[0] = i; }else if ((counts[i] == max) && (counts[i] !=0)) { bufMax[strlen(bufMax)] = i; } } printf("出現最多的字符分別為:"); for (int i=0; i<strlen(bufMax); i++) { printf("%c ", bufMax[i]); } printf("/n"); printf("出現最多的字符的次數:%d/n", max);}int main(){ char* srcData = "aabbbcddddeeffffghijklmnopqrst"; search(srcData, strlen(srcData)); getchar(); return 1;}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答