2018/10/13 Day002

本文深入探讨了三个编程领域的复杂问题:JavaScript中函数返回值的微妙差异,MySQL中筛选高分学生的SQL查询技巧,以及Java中计算球体反弹高度的递归方法。这些问题不仅考验了程序员的基础知识,还展示了实际编程中可能遇到的陷阱。

JavaScript编程题

下面两个函数的返回值是一样的吗?为什么?

function foo1() {
	return {
		bar: "hello"
	};
}

function foo2() {
    return
	{
		bar: "hello"
	};
}

在编程语言中,基本都是使用分号(;)将语句分隔开,这可以增加代码的可读性和整洁性。而在 JS 中,如若语句各占独立一行,通常可以省略语句间的分号(;),JS 解析器会根据能否正常编译来决定是否自动填充分号:

var test = 1 + 2;
console.log(test); //3

在上述情况中,为了正确解析代码,就不会自动填充分号了,但是对于 return 、break、continue 等语句,如果后面紧跟换行,解析器一定会自动在后面填充分号(;),所以上面的第二个函数就变成了这样:

function foo2() {
	return;
	{
		bar: "hello"
	};
}

所以第二个函数是返回 undefined。

MySQL编程题

用一条 SQL 语句,查询出每门课都大于 80 分的学生姓名。
表名 student_score

namecoursescore
张三语文81
张三数学75
李四语文76
李四数学90
王五语文81
王五数学100
王五英语90
select distinct name from student_score where name not in (select distinct name from student_score where score <= 80);

或者

select name from student_score group by name having min(score)>80;

JAVA编程题

一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第 10 次落地时,共经过多少米?第 10 次反弹多高?

package test;

public class Test2 {
	/**
	 * 
	 * @param h 距离
	 * @param n 次数
	 * @return 第n次反弹的高度
	 */
	public static double sumBallHeight(double h, int n) {
		if (n == 1)
			return h / 2;
		else
			return sumBallHeight(h / 2, n - 1);
	}

	public static void main(String[] args) {
		System.out.println(sumBallHeight(100, 10));
	}
}

package test;

public class Tl2 {

	public static void sumBallHeight(int initHeight, int times) {
		// 落地时经过多少米
		double sum = 0;
		// 反弹高度
		double height = 0;
		for (int i = 1; i <= times; i++) {
			if (i == 1) {
				height  = initHeight/2;
				sum += initHeight;
			} else {
				sum = sum + height * 2;
				height = height/2;
			}
		}
		System.out.println("第" + times + "次落地时,共经过" + sum + "米");
		System.out.println("第" + times + "次反弹" + height + "米");
	}

	public static void main(String[] args) {
		sumBallHeight(100, 3);
	}
}


``` {—————————————— 系统参数模块 ——————————————} {——估值体系优化——} DYNPETTM:=IF(FINANCE(33)>0, CLOSE/(FINANCE(33)/FINANCE(1)+0.0001), 1000); {动态市盈率} PB_RATE:=IF(FINANCE(5)>0, CLOSE/FINANCE(5), 1000); {修正市净率} PEG_VAL:=DYNPETTM/MAX(FINANCE(54)/FINANCE(34)*100,0.0001); {净利润增长率保护} {——波动率自适应系统——} VOLATILITY:=STD(CLOSE,20)/MA(CLOSE,20); VAR_PERIOD:=IF(VOLATILITY<0.08,55,IF(VOLATILITY<0.15,34,21)); FAST_LEN:=MAX(5, INTPART(VAR_PERIOD*0.382 + 0.5)); SLOW_LEN:=MIN(60, INTPART(VAR_PERIOD*1.618 + 0.5)); SGNL_LEN:=IF(VAR_PERIOD<=21,7,9); {——多周期参数优化——} KDJ_N:=IF(VOLATILITY<0.1,14,9); RSI_N:=IF(VOLATILITY<0.15,14,7); BOLL_N:=20; MOM_N:=IF(VOLATILITY>0.2,13,21); {—————————————— 核心指标系统 ——————————————} {——MACD自适应系统增强——} DIF:=EMA(CLOSE,FAST_LEN) - EMA(CLOSE,SLOW_LEN); DEA:=EMA(DIF,SGNL_LEN); MACD:=2*(DIF-DEA); MACD_ANGLE:=ATAN((DIF-REF(DIF,1))/0.1)*180/3.1416; {——均线系统强化——} MA5:=MA(CLOSE,5); MA10:=MA(CLOSE,10); MA20:=EMA(CLOSE,20); MA60:=EMA(CLOSE,60); TREND_ARR:=MA5>MA10 AND MA10>MA20 AND MA20>MA60 AND CLOSE>MA5*1.03; {——量能系统优化——} VOL_MA5:=MA(VOL,5); VOL_MA20:=EMA(VOL,20); VOL_SIG:=VOL>VOL_MA20*1.5 AND VOL>REF(HHV(VOL,5),1)*1.2 AND VOL>MA(VOL,60)*1.8; {——动量确认系统——} MOMENTUM:=EMA(CLOSE,5)/REF(EMA(CLOSE,MOM_N),5)-1; WEEK_CHG:=(CLOSE-REF(CLOSE,5))/REF(CLOSE,5)*100; MOM_CONF:=EMA(CLOSE,5) > EMA(CLOSE,13) AND CLOSE > HHV(CLOSE*0.75,34) AND MACD_ANGLE>15; {——KDJ系统优化——} RSV:=(CLOSE-LLV(LOW,KDJ_N))/(HHV(HIGH,KDJ_N)-LLV(LOW,KDJ_N)+0.0001)*100; K:=SMA(RSV,3,1); D:=SMA(K,3,1); J:=3*K-2*D; KDJ_GC:=CROSS(K,D) AND D<45 AND J>30; {——布林带系统增强——} MID:=MA(CLOSE,BOLL_N); UPPER:=MID + 2*STD(CLOSE,BOLL_N); LOWER:=MID - 2*STD(CLOSE,BOLL_N); BWIDTH:=(UPPER-LOWER)/MID*100; BOLL_SIG:=CLOSE>UPPER*0.98 AND BWIDTH>10; {—————————————— 信号生成系统 ——————————————} {——核心条件集成——} VALUATION:=DYNPETTM<35 AND PB_RATE<4.5 AND PEG_VAL<1.2 AND FINANCE(30)/FINANCE(1)>0.15; TREND_SIG:=TREND_ARR AND CLOSE>MA60*1.05 AND CLOSE<MA60*1.25; MOM_SIG:=CROSS(DIF,DEA) AND MACD>REF(MACD,1) AND J>REF(J,1) AND MACD_ANGLE>15; PRICE_VOL:=VOL_SIG AND ABS((CLOSE-OPEN)/(HIGH-LOW+0.0001))>0.6 AND BOLL_SIG; {——风险过滤系统——} BETA_COEF:=SLOPE(CLOSE/INDEXC,60)*STD(CLOSE,60)/STD(INDEXC,60); RISK_FLT:=BETA_COEF>=0.8 AND BETA_COEF<=1.2 AND FINANCE(42)/FINANCE(1)<0.6 AND FINANCE(10)/FINANCE(1)>0.3; {——周期协同系统优化——} CY_MON:=MA(CLOSE,10)>REF(MA(CLOSE,10),3) AND MA(CLOSE,20)>REF(MA(CLOSE,20),5); CY_WK_DIFF:=EMA(CLOSE,12) - EMA(CLOSE,26); CY_WK_DEA:=EMA(CY_WK_DIFF,9); CY_WK:=CY_WK_DIFF>REF(CY_WK_DEA,1) AND CY_WK_DIFF>0; CY_HR_RSV1:=SMA(MAX(CLOSE-REF(CLOSE,1),0),14,1); CY_HR_RSV2:=SMA(ABS(CLOSE-REF(CLOSE,1)),14,1); CY_HR:=CY_HR_RSV1/CY_HR_RSV2*100>60 AND MA(VOL,3)>REF(MA(VOL,3),1)*1.2; {—————————————— 信号合成系统 ——————————————} DAY_ALERT:=TREND_SIG AND MOM_SIG AND PRICE_VOL AND RISK_FLT AND CY_HR; SCAN_SIG:=VALUATION AND CY_MON AND CY_WK AND COUNT(DAY_ALERT,5)>=2 AND FINANCE(56)/FINANCE(55)>1.15 AND WEEK_CHG>HHV(WEEK_CHG,20)*0.7 AND EVERY(CLOSE>OPEN,3); {——风控系统增强——} ATR_VALUE:=MA(TR,14); STOP_LOSS:=MAX(MAX(MA10*0.93, LLV(LOW,10)*0.95), CLOSE - 2.5*ATR_VALUE); TAKE_PROFIT:=IF(VOLATILITY<0.1, HHV(HIGH,20)*1.25, HHV(HIGH,13)*1.35); RISK_RATIO:=IF(BETA_COEF>1, 1.25/BETA_COEF,1); STOP_PRICE:=STOP_LOSS * RISK_RATIO; PROFIT_PRICE:=TAKE_PROFIT * RISK_RATIO; {——最终信号合并——} FINAL_SIGNAL:FILTER(DAY_ALERT OR SCAN_SIG,5);```你的身份是高级编程技术专家,精通各类编程语言,能对编程过程中的各类问题进行分析和解答。我的问题是【我正在编辑【通达信量化择时周线选股】代码,我的选股逻辑是什么?用2015-2024年全A股验证选股逻辑的准确性,并提出优化建议和方案,所有参数计算关系和信号触发条件,是否选到盘中异动,启动主升浪的股票,及日线盘中预警选股和盘后选股,去除冗余选股条件】,请帮我检查并补全正确代码,生成修正后完整代码。
最新发布
03-24
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值