剖析Framework面试 冲击Android高级职位

download:剖析Framework面试 冲击Android高级职位

本次课程着重为大家讲解Android系统底层原理,补齐Android开发的Framework层知识短板。一方面对高级工程师的面试提供直接帮助,另一方面有效地提高大家的技术段位。兼顾面试知识技能与开发内功的提升,课程适合每一位Android中高级开发者。
适合人群
具有一定开发经验,想搞定Android高级面试的工程师
想利于工作之余,深入学习Framework系统原理的工程师
技术储备要求
1.有一定的Android应用开发经验 2.熟悉jni原理
3.最好有一定C++语法基础 4.了解基本的Linux系统调用





标题:有1、2、3、4个数字,能组成几个互不相同且无反复数字的三位数?都是几?
1.程序剖析:可填在百位、十位、个位的数字都是1、2、3、4。组成一切的排列后再去
      掉不满足条件的排列。
2.程序源代码:
main()
{
int i,j,k;
printf("\n");
for(i=1;i<5;i++)    /以下为三重循环/
 for(j=1;j<5;j++) 
  for (k=1;k<5;k++)
   {
    if (i!=k&&i!=j&&j!=k)    /确保i、j、k三位互不相同/
    printf("%d,%d,%d\n",i,j,k);
   }
}














【程序2】
标题:企业发放的奖金依据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高
   于10万元,低于20万元时,低于10万元的局部按10%提成,高于10万元的局部,可可提
   成7.5%;20万到40万之间时,高于20万元的局部,可提成5%;40万到60万之间时高于
   40万元的局部,可提成3%;60万到100万之间时,高于60万元的局部,可提成1.5%,高于
   100万元时,超越100万元的局部按1%提成,从键盘输入当月利润I,求应发放奖金总数?
1.程序剖析:请应用数轴来分界,定位。留意定义时需把奖金定义生长整型。      
2.程序源代码:
main()
{
long int i;
int bonus1,bonus2,bonus4,bonus6,bonus10,bonus;
scanf("%ld",&i);
bonus1=1000000.1;bonus2=bonus1+1000000.75;
bonus4=bonus2+2000000.5;
bonus6=bonus4+200000
0.3;
bonus10=bonus6+4000000.15;
 if(i<=100000)
  bonus=i

0.1;
 else if(i<=200000)
     bonus=bonus1+(i-100000)0.075;
    else if(i<=400000)
        bonus=bonus2+(i-200000)

0.05;
       else if(i<=600000)
           bonus=bonus4+(i-400000)0.03;
          else if(i<=1000000)
              bonus=bonus6+(i-600000)

0.015;
             else
              bonus=bonus10+(i-1000000)0.01;
printf("bonus=%d",bonus);
} ==============================================================
【程序3】
标题:一个整数,它加上100后是一个完整平方数,再加上168又是一个完整平方数,请问该数是几?
1.程序剖析:在10万以内判别,先将该数加上100后再开方,再将该数加上268后再开方,假如开方后
      的结果满足如下条件,即是结果。请看详细剖析:
2.程序源代码:
#include "math.h"
main()
{
long int i,x,y,z;
for (i=1;i<100000;i++)
 { x=sqrt(i+100);   /












x为加上100后开方后的结果/
  y=sqrt(i+268);   /
y为再加上168后开方后的结果/
   if(x
x==i+100&&yy==i+268)/假如一个数的平方根的平方等于该数,这阐明此数是完整平方数*/
    printf("\n%ld\n",i);
 }
}























【程序4】
标题:输入某年某月某日,判别这一天是这一年的第几天?
1.程序剖析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊
      状况,闰年且输入月份大于3时需思索多加一天。
2.程序源代码:
main()
{
int day,month,year,sum,leap;
printf("\nplease input year,month,day\n");
scanf("%d,%d,%d",&year,&month,&day);
switch(month)/先计算某月以前月份的总天数/
{
 case 1:sum=0;break;
 case 2:sum=31;break;
 case 3:sum=59;break;
 case 4:sum=90;break;
 case 5:sum=120;break;
 case 6:sum=151;break;
 case 7:sum=181;break;
 case 8:sum=212;break;
 case 9:sum=243;break;
 case 10:sum=273;break;
 case 11:sum=304;break;
 case 12:sum=334;break;
 default:printf("data error");break;
}
sum=sum+day;  /再加上某天的天数/
 if(year%400==0||(year%4==0&&year%100!=0))/判别是不是闰年/
  leap=1;
 else
  leap=0;
if(leap==1&&month>2)/假如是闰年且月份大于2,总天数应该加一天/
sum++;
printf("It is the %dth day.",sum);}
































【程序5】
标题:输入三个整数x,y,z,请把这三个数由小到大输出。
1.程序剖析:我们想方法把最小的数放到x上,先将x与y停止比拟,假如x>y则将x与y的值停止交流,
      然后再用x与z停止比拟,假如x>z则将x与z的值停止交流,这样能使x最小。
2.程序源代码:
main()
{
int x,y,z,t;
scanf("%d%d%d",&x,&y,&z);
if (x>y)
{t=x;x=y;y=t;} /交流x,y的值/
if(x>z)
{t=z;z=x;x=t;}/交流x,z的值/
if(y>z)
{t=y;y=z;z=t;}/交流z,y的值/
printf("small to big: %d %d %d\n",x,y,z);














發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章