查表法

查表法是将一些事先计算好的结果,存储在常量数组中,运行时节省计算开销。

例如,

计算字节中位1的个数,

int countBits( unsigned char dat )

{

   static char nBitTab[256] = { 0, 1, 1, 2, 1, 2, 2, 3, 1, ...... };

   return nBitTab[dat];

}

或将字节按位逆序,

unsigned char reverse( unsigned char dat )

{

   static char revTab[256] = { 0x0, 0x80, 0x40, ......};

   return nBitTab[dat];

}

或计算0~360度的正弦值,

int sin( int ang )
{
 static const int sinV[] = {
   /*sin00=*/0, 1144,2287,3430,4572,5712,6850,7987,9121,10252,
   /*sin10=*/11380,12505,13626,14742,15855,16962,18064,19161,20252,21336,
   /*sin20=*/22415,23486,24550,25607,26656,27697,28729,29753,30767,31772,
   /*sin30=*/32768,33754,34729,35693,36647,37590,38521,39441,40348,41243,
   /*sin40=*/42126,42995,43852,44695,45525,46341,47143,47930,48703,49461,
   /*sin50=*/50203,50931,51643,52339,53020,53684,54332,54963,55578,56175,
   /*sin60=*/56756,57319,57865,58393,58903,59396,59870,60326,60764,61183,
   /*sin70=*/61584,61966,62328,62672,62997,63303,63589,63856,64104,64332,
   /*sin80=*/64540,64729,64898,65048,65177,65287,65376,65446,65496,65526,
   /*sin90=*/65536,  
   };
 if ( 0 <= ang && ang <= 90 )
 {
  return sinV[ang];
 }
 if ( 90 < ang && ang <= 180 )
 {
  return sinV[180-ang];
 }
 if ( 180 < ang && ang <= 270 )
 {
  return -sinV[ang-180];
 }
 if ( 270 < ang && ang < 360 )
 {
  return -sinV[360-ang];
 }
 return 0;
}

理论上,y=f(x),x的取值范围为有限种状态,且f(x)有一定运算量时,都可以考虑查表法。
如,前两个例子中x的范围是字节的256个值,第三个例子是0~90度。


/** 
* 数组的操作————查表法 
* eg : 数组查表法(根据键盘录入索引,查找对应星期) 
*/  
import java.util.Scanner;  
public class arraynum {  
public static void main(String[] args) {  
Scanner sc = new Scanner(System.in);  
System.out.println("请输入对应的星期范围在1-7");  
  
int week = sc.nextInt();  
//sc.close();  
System.out.println("星期" + getWeek(week));  
}  
  
  
/* 
根据索引返回对应的星期 
1,返回值类型char 
2,参数列表int week 
*/  
//数组第0个元素为null,这样1就对应的一,以此类推  
public static char getWeek(int week) {  
char[] arr = {' ','一','二','三','四','五','六','日'};//定义了一张星期表  
return arr[week];//通过索引获取表中的元素  
}  
}  

另外,查表法还用于简化switch/case语句,还可将数据与代码分离。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,706评论 4 366
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,002评论 1 301
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,462评论 0 250
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,375评论 0 216
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,763评论 3 294
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,849评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,033评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,768评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,490评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,734评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,204评论 1 264
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,566评论 3 260
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,227评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,137评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,934评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,926评论 2 283
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,774评论 2 274

推荐阅读更多精彩内容