微软必应·英雄会第三届在线编程大赛:几个bing? 题目解析

失落夏天
Android领域优质创作者
博客专家认证
2014-01-03 06:43:50
加精
解题思路在博客里写了http://blog.csdn.net/rzleilei/article/details/17796523
代码如下。

另外本人欢迎提供或交流类似的编程题目。

题目详情:

本届大赛由微软必应词典冠名,必应词典(http://cn.bing.com/dict/?form=BDVSP4&mkt=zh-CN&setlang=ZH)是微软推出的新一代英语学习引擎,里面收录了很多我们常见的单词。但现实生活中,我们也经常能看到一些毫无规则的字符串,导致词典无法正常收录,不过,我们是否可以从无规则的字符串中提取出正规的单词呢?

例如有一个字符串"iinbinbing",截取不同位置的字符‘b’、‘i’、‘n’、‘g’组合成单词"bing"。若从1开始计数的话,则‘b’ ‘i’ ‘n’ ‘g’这4个字母出现的位置分别为(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10),故总共可以组合成4个单词”bing“。

咱们的问题是:现给定任意字符串,只包含小写‘b’ ‘i’ ‘n’ ‘g’这4种字母,请问一共能组合成多少个单词bing?

字符串长度不超过10000,由于结果可能比较大,请输出对10^9 + 7取余数之后的结果。


public class Test4 {
static char[] ch;
static int index=0;
static int b_num=0;
static int i_num=0;
static int n_num=0;
static int num=0;

public static void main(String[] args) {

System.out.println(getNum("iinbinbinginng"));
}

public static int getNum(String str){
ch=str.toCharArray();
for (int i = 0; i < ch.length; i++) {
switch (ch[i]) {
case 'b':
b_num++;
break;
case 'i':
i_num+=b_num;
break;
case 'n':
n_num+=i_num;
break;
case 'g':
num+=n_num;
break;
default:
break;
}
}
return num%(10^9+7);
}
}
...全文
3204 56 打赏 收藏 转发到动态 举报
写回复
用AI写文章
56 条回复
切换为时间正序
请发表友善的回复…
发表回复
中琦 2014-07-30
  • 打赏
  • 举报
回复
这个题目 考量的 关键之处在于: 拿这个“bingng” 来举例,取到第一个 n 的时候后面两个 g ,都能凑上 “bing” 单词,但是取第二个 n 的话 就只能取 第二个 g 来凑 “bing” 了
中琦 2014-07-30
  • 打赏
  • 举报
回复
引用 48 楼 freednc 的回复:
[quote=引用 47 楼 AA5279AA 的回复:] [quote=引用 46 楼 freednc 的回复:] [quote=引用 楼主 AA5279AA 的回复:] 解题思路在博客里写了http://blog.csdn.net/rzleilei/article/details/17796523 代码如下。 另外本人欢迎提供或交流类似的编程题目。 题目详情: 本届大赛由微软必应词典冠名,必应词典(http://cn.bing.com/dict/?form=BDVSP4&mkt=zh-CN&setlang=ZH)是微软推出的新一代英语学习引擎,里面收录了很多我们常见的单词。但现实生活中,我们也经常能看到一些毫无规则的字符串,导致词典无法正常收录,不过,我们是否可以从无规则的字符串中提取出正规的单词呢? 例如有一个字符串"iinbinbing",截取不同位置的字符‘b’、‘i’、‘n’、‘g’组合成单词"bing"。若从1开始计数的话,则‘b’ ‘i’ ‘n’ ‘g’这4个字母出现的位置分别为(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10),故总共可以组合成4个单词”bing“。 咱们的问题是:现给定任意字符串,只包含小写‘b’ ‘i’ ‘n’ ‘g’这4种字母,请问一共能组合成多少个单词bing? 字符串长度不超过10000,由于结果可能比较大,请输出对10^9 + 7取余数之后的结果。

public class Test4 {
	static char[] ch;
	static int index=0;
	static int b_num=0;
	static int i_num=0;
	static int n_num=0;
	static int num=0;
	
	public static void main(String[] args) {
		
		System.out.println(getNum("iinbinbinginng"));
	}
	
	public static int getNum(String str){
		ch=str.toCharArray();
		for (int i = 0; i < ch.length; i++) {
			switch (ch[i]) {
			case 'b':
				b_num++;
				break;
			case 'i':
				i_num+=b_num;
				break;
			case 'n':
				n_num+=i_num;
				break;
			case 'g':
				num+=n_num;
				break;
			default:
				break;
			}
		}
		return num%(10^9+7);
	}
}
以题目中的示例“iinbinbing”作为输入 得到的结果是18,但是题目中不是说了 是4个吗?[/quote] 请输出对10^9 + 7取余数之后的结果。 [/quote] 我看错了 不好意思[/quote] 第一页全是特么的点赞党,楼主连题目意思都没弄懂,这些看客也没几个弄懂意思么。??还好意思贴出代码。? 知道组成单词是什么意思么。?? 按照顺序 bing 才是想要的结果。 你那些遍历把 nbig bnig 什么的都加到结果中去了。 难道你就没发现你的结果和别人的结果不一样么。??
楊松坤 2014-02-19
  • 打赏
  • 举报
回复
凑个热闹QQ:125004485
吃鸟的虫 2014-02-15
  • 打赏
  • 举报
回复
和楼主思路相同,不过是反向思维 ,由g->b,的过程 (并且没精简……) 遗憾啊,昨天中午看到还有这样的挑战题, 昨天挑战,第一回根本没去考虑效率,挑战失败。 今天早上躺在床上,想了下,然后饭桌子上画了1个小时,想检验下的,时间好像过了啊。没找到那个页面了。 最后如下: int getCountOfBing(char *str) { long long gCount = 0; long long nCount = 0, ngCount = 0; long long iCount = 0, inCount = 0, ingCount = 0; long long bCount=0,biCount = 0,binCount = 0,bingCount = 0; int curPos = 0; if (curPos = getLastPos('g',str,0,strlen(str))) { gCount=1; } int movePos = 0; if(movePos = getLastPos('n',str,0,curPos)) { nCount = 1; if (gCount == 1) { ngCount=1; } } if (ngCount == 1) { while (--movePos>=0) { switch(str[movePos]) { case 'g': gCount++; break; case 'n': nCount++; ngCount+=gCount; break; case 'i': iCount++; inCount+=nCount; ingCount+=ngCount; break; case 'b': bCount++; bingCount+=ingCount; break; default: printf("*"); break; } } } printf("ng: %lld\t",ngCount); printf("ing: %lld\n",ingCount); return bingCount%1000000007; }
贝拉的魔法 2014-02-14
  • 打赏
  • 举报
回复
果然厉害,开始试验看错了,以至于我认为楼主的是错误的,真惭愧啊
line_us 2014-02-03
  • 打赏
  • 举报
回复
你的好简洁的说.:
realmagician 2014-02-02
  • 打赏
  • 举报
回复
思路类似:
namespace CSharpHelloWorld
{
    class Program
    {
        static void Main(string[] args)
        {
            int modBase = 10 ^ 9 + 7;
            StringBuilder dataSB = new StringBuilder("iibbingng");
            int length = dataSB.Length;
            int[] dps = new int[4];
            for (int ids = 0; ids < length; ++ids)
            {
                switch (dataSB[ids])
                {
                    case 'b': dps[0] = (dps[0] + 1) % modBase; break;
                    case 'i': dps[1] = (dps[0] + dps[1]) % modBase; break;
                    case 'n': dps[2] = (dps[1] + dps[2]) % modBase; break;
                    case 'g': dps[3] = (dps[2] + dps[3]) % modBase; break;
                }
            }
            Console.WriteLine(dps[3]);
        }
    }
}
梨花树下思考 2014-01-22
  • 打赏
  • 举报
回复
引用 45 楼 freednc 的回复:
[quote=引用 35 楼 u013472757 的回复:] c# 代码
		public int howmany(string s)
			
		{
			ulong b=0, bi=0,bin=0,bing=0;
			
			foreach(char bbb in s)
			{
				if(bbb=='b') b++;
				if(bbb=='i') bi+=b;
				if(bbb=='n') bin+=bi;
				if(bbb=='g') bing+=bin;
				
			}
			return (int)(bing % (1000000000+7));
			
		}
地铁上想出来的,绝对原创,速度极快,如有雷同,就是思路相同了
以题目中的示例“iinbinbing”作为输入 得到的结果是18,但是题目中不是说了 是4个吗? [/quote] 我看错了 不好意思。
梨花树下思考 2014-01-22
  • 打赏
  • 举报
回复
引用 47 楼 AA5279AA 的回复:
[quote=引用 46 楼 freednc 的回复:] [quote=引用 楼主 AA5279AA 的回复:] 解题思路在博客里写了http://blog.csdn.net/rzleilei/article/details/17796523 代码如下。 另外本人欢迎提供或交流类似的编程题目。 题目详情: 本届大赛由微软必应词典冠名,必应词典(http://cn.bing.com/dict/?form=BDVSP4&mkt=zh-CN&setlang=ZH)是微软推出的新一代英语学习引擎,里面收录了很多我们常见的单词。但现实生活中,我们也经常能看到一些毫无规则的字符串,导致词典无法正常收录,不过,我们是否可以从无规则的字符串中提取出正规的单词呢? 例如有一个字符串"iinbinbing",截取不同位置的字符‘b’、‘i’、‘n’、‘g’组合成单词"bing"。若从1开始计数的话,则‘b’ ‘i’ ‘n’ ‘g’这4个字母出现的位置分别为(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10),故总共可以组合成4个单词”bing“。 咱们的问题是:现给定任意字符串,只包含小写‘b’ ‘i’ ‘n’ ‘g’这4种字母,请问一共能组合成多少个单词bing? 字符串长度不超过10000,由于结果可能比较大,请输出对10^9 + 7取余数之后的结果。

public class Test4 {
	static char[] ch;
	static int index=0;
	static int b_num=0;
	static int i_num=0;
	static int n_num=0;
	static int num=0;
	
	public static void main(String[] args) {
		
		System.out.println(getNum("iinbinbinginng"));
	}
	
	public static int getNum(String str){
		ch=str.toCharArray();
		for (int i = 0; i < ch.length; i++) {
			switch (ch[i]) {
			case 'b':
				b_num++;
				break;
			case 'i':
				i_num+=b_num;
				break;
			case 'n':
				n_num+=i_num;
				break;
			case 'g':
				num+=n_num;
				break;
			default:
				break;
			}
		}
		return num%(10^9+7);
	}
}
以题目中的示例“iinbinbing”作为输入 得到的结果是18,但是题目中不是说了 是4个吗?[/quote] 请输出对10^9 + 7取余数之后的结果。 [/quote] 我看错了 不好意思
失落夏天 2014-01-22
  • 打赏
  • 举报
回复
引用 46 楼 freednc 的回复:
[quote=引用 楼主 AA5279AA 的回复:] 解题思路在博客里写了http://blog.csdn.net/rzleilei/article/details/17796523 代码如下。 另外本人欢迎提供或交流类似的编程题目。 题目详情: 本届大赛由微软必应词典冠名,必应词典(http://cn.bing.com/dict/?form=BDVSP4&mkt=zh-CN&setlang=ZH)是微软推出的新一代英语学习引擎,里面收录了很多我们常见的单词。但现实生活中,我们也经常能看到一些毫无规则的字符串,导致词典无法正常收录,不过,我们是否可以从无规则的字符串中提取出正规的单词呢? 例如有一个字符串"iinbinbing",截取不同位置的字符‘b’、‘i’、‘n’、‘g’组合成单词"bing"。若从1开始计数的话,则‘b’ ‘i’ ‘n’ ‘g’这4个字母出现的位置分别为(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10),故总共可以组合成4个单词”bing“。 咱们的问题是:现给定任意字符串,只包含小写‘b’ ‘i’ ‘n’ ‘g’这4种字母,请问一共能组合成多少个单词bing? 字符串长度不超过10000,由于结果可能比较大,请输出对10^9 + 7取余数之后的结果。

public class Test4 {
	static char[] ch;
	static int index=0;
	static int b_num=0;
	static int i_num=0;
	static int n_num=0;
	static int num=0;
	
	public static void main(String[] args) {
		
		System.out.println(getNum("iinbinbinginng"));
	}
	
	public static int getNum(String str){
		ch=str.toCharArray();
		for (int i = 0; i < ch.length; i++) {
			switch (ch[i]) {
			case 'b':
				b_num++;
				break;
			case 'i':
				i_num+=b_num;
				break;
			case 'n':
				n_num+=i_num;
				break;
			case 'g':
				num+=n_num;
				break;
			default:
				break;
			}
		}
		return num%(10^9+7);
	}
}
以题目中的示例“iinbinbing”作为输入 得到的结果是18,但是题目中不是说了 是4个吗?[/quote] 请输出对10^9 + 7取余数之后的结果。
梨花树下思考 2014-01-22
  • 打赏
  • 举报
回复
引用 楼主 AA5279AA 的回复:
解题思路在博客里写了http://blog.csdn.net/rzleilei/article/details/17796523 代码如下。 另外本人欢迎提供或交流类似的编程题目。 题目详情: 本届大赛由微软必应词典冠名,必应词典(http://cn.bing.com/dict/?form=BDVSP4&mkt=zh-CN&setlang=ZH)是微软推出的新一代英语学习引擎,里面收录了很多我们常见的单词。但现实生活中,我们也经常能看到一些毫无规则的字符串,导致词典无法正常收录,不过,我们是否可以从无规则的字符串中提取出正规的单词呢? 例如有一个字符串"iinbinbing",截取不同位置的字符‘b’、‘i’、‘n’、‘g’组合成单词"bing"。若从1开始计数的话,则‘b’ ‘i’ ‘n’ ‘g’这4个字母出现的位置分别为(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10),故总共可以组合成4个单词”bing“。 咱们的问题是:现给定任意字符串,只包含小写‘b’ ‘i’ ‘n’ ‘g’这4种字母,请问一共能组合成多少个单词bing? 字符串长度不超过10000,由于结果可能比较大,请输出对10^9 + 7取余数之后的结果。

public class Test4 {
	static char[] ch;
	static int index=0;
	static int b_num=0;
	static int i_num=0;
	static int n_num=0;
	static int num=0;
	
	public static void main(String[] args) {
		
		System.out.println(getNum("iinbinbinginng"));
	}
	
	public static int getNum(String str){
		ch=str.toCharArray();
		for (int i = 0; i < ch.length; i++) {
			switch (ch[i]) {
			case 'b':
				b_num++;
				break;
			case 'i':
				i_num+=b_num;
				break;
			case 'n':
				n_num+=i_num;
				break;
			case 'g':
				num+=n_num;
				break;
			default:
				break;
			}
		}
		return num%(10^9+7);
	}
}
以题目中的示例“iinbinbing”作为输入 得到的结果是18,但是题目中不是说了 是4个吗?
梨花树下思考 2014-01-22
  • 打赏
  • 举报
回复
引用 35 楼 u013472757 的回复:
c# 代码
		public int howmany(string s)
			
		{
			ulong b=0, bi=0,bin=0,bing=0;
			
			foreach(char bbb in s)
			{
				if(bbb=='b') b++;
				if(bbb=='i') bi+=b;
				if(bbb=='n') bin+=bi;
				if(bbb=='g') bing+=bin;
				
			}
			return (int)(bing % (1000000000+7));
			
		}
地铁上想出来的,绝对原创,速度极快,如有雷同,就是思路相同了
以题目中的示例“iinbinbing”作为输入 得到的结果是18,但是题目中不是说了 是4个吗?
woodangel 2014-01-19
  • 打赏
  • 举报
回复
为了速度在编程比赛中可以这样玩,在平时编程中这样玩很危险,程序还是朴实点好。
崦嵫 2014-01-19
  • 打赏
  • 举报
回复
引用 43 楼 woodangel 的回复:
为了速度在编程比赛中可以这样玩,在平时编程中这样玩很危险,程序还是朴实点好。
+1
慢慢地转变 2014-01-18
  • 打赏
  • 举报
回复
曾经发了个求解提高这道题目效率的帖子,石城大海,现在看来,自己的思维亟待提高啊。
woodangel 2014-01-18
  • 打赏
  • 举报
回复
这种解法是否可以认为是“玩花活”“玩技巧”?如果客户用了这个程序摆摆手说,除了要给出个数外,我还想要给出"BING"分布的具体位置,这样是否要重新编写?
guaguo02100 2014-01-14
  • 打赏
  • 举报
回复
我承认,if没有switch case快
guaguo02100 2014-01-14
  • 打赏
  • 举报
回复
c# 代码
		public int howmany(string s)
			
		{
			ulong b=0, bi=0,bin=0,bing=0;
			
			foreach(char bbb in s)
			{
				if(bbb=='b') b++;
				if(bbb=='i') bi+=b;
				if(bbb=='n') bin+=bi;
				if(bbb=='g') bing+=bin;
				
			}
			return (int)(bing % (1000000000+7));
			
		}
地铁上想出来的,绝对原创,速度极快,如有雷同,就是思路相同了
鲸鱼先生 2014-01-14
  • 打赏
  • 举报
回复
瞬间感觉自己弱爆了。
wxyvgo 2014-01-14
  • 打赏
  • 举报
回复
牛人的思维!!! 佩服
加载更多回复(32)
《Core Java》介绍和我的课程计划 李冰Email: bing.li@asu.eduWeChat: libertymama2021年4月15日 这是我第一次通过录屏的方式讲授主流程序设计技术。从今年二月底至今,我已经录制了105讲52.5小时的视频课程。通过这段时间的工作,我认为借助互联网强大的传播能力,这种新型教育方式完全具备超越传统实体模式的巨大优势,一定成为未来教育的发展趋势。我积极投入到这项事业当中,尽我所能提供更多高质量在线教学课程。 一、本课程内容 本课程将以Cay Horstmann的经典著作《Core Java》(第11版,2019年)为蓝本面向广大程序设计爱好者以及专业人员讲授基础Java程序设计技术。对于主流程序设计语言的教学,教材的选用对教学效果具有决定意义。我虽然有大量Java语言开发经验,但并没有时间和精力按照我自己的理解写一部教材。在这种情况下,不妨在现有资料中做出恰当选择。在长期Java程序开发过程中,我收集的各种Java程序设计书籍超过50部。它们包括基础技术、设计模式、并发技术、数据处理、网络通信、性能优化、代码测试以及高级技巧等多个方面。通过对这些书籍的比较,我认为《Core Java》是全面介绍Java技术的经典教材。它篇幅宏大,对Java标准版(Java Standard Edition – JSE)大大小小各种问题做了细致入微的介绍。对学习者来说,它无疑是众多介绍Java基础技术书籍中的最佳选择。 为了方便学习者掌握本书,我对全书内容进行了摘要并编纂成幻灯片。在这个准备过程中,即使作为拥有大量程序设计经验的我来说,我也发现了我对一些细节认识的模糊,有的甚至从来没有接触过。事实上,这些细节对于我们提高程序质量是大有裨益的。作为基础程序设计技术的经典之作,本书除了有翔实完整的描述外,还包括大量具有充分说服力的程序示例。这体现了计算机科学作为当代最重要的科学分支之一所独有的理性诉求。为了使学习者更深入了解每一项技术,我还额外增添了很多程序示例,更加丰富了本课程的内容。这些示例使得全书所有论述都是建立在代码支持的基础上,成为学习Java程序设计技术最坚实的保证。 还有一点我需要说明的是,作为本课程的主讲者,我并不是简单地照本宣科。根据我的研发和教学经验,对程序设计这样一门复杂技术来说,主讲者以往和当前所从事的研发工作对讲课质量有着至关重要的影响。我把我在研发中的实际体融入在整个讲课过程中。对所有重要技术,除了清晰阐述原作者观念以外,我提供我个人的评价供学习者参考;同时,我还收集其他资料作为辅助,使得对特定技术的解释更加充分。通过多角度的观察体验,促使学习者全面透彻理解Java语言。我认为这种个性多元的教学方式是帮助大家掌握程序设计的关键所在。 由于本书的庞大容量,我还没有足够时间完成全书的录制。我坚持完成所有课程,估计在六月中完成第一卷全部十二章内容;在八月底完成第二卷的录制。保守估计,完成后全部幻灯片页数超过3,000页;程序示例个数超过700个;全部代码程序超过15,000行;全部视频课程时长至少达到150小时,即300讲。当前,我已经完成本书第一卷前五章和第六章部分内容的录制,现在共有105讲(52.5小时)的视频,幻灯片达到1,222页。其中包括212个程序示例,共5,130行代码。在完成本书的全部录制之后,本课程将成为国内全网范围内时间最长和内容最丰富的Java基础技术视频教材。 当然,《Core Java》这本书也有它的不足。在全面覆盖Java标准版的同时,对一些重点问题的介绍深度上有欠缺。这对于一部力图囊括所有Java基础技术的教材来说也在所难免。为了弥补这个不足,我将在其他课程中予以弥补。这些课程也同样是基于知名经典著作进行介绍。我的初步计划涉及的著作包括:Steven John Metker的《Design Patterns Java Workbook》、Brian Goetz等的《Java Concurrency In Practice》、Elliotte Rusty Harold的《Java Network Programming》、Charlie Hunt和Binu John的《Java Performance》、Ira Forman和Nate Forman的《Java Reflection in Action》以及Maurice Naftalin和Philip Wadler的《Java Generic and Collections》。另外,我还计划把最新出版的其他重要英文程序设计专著在不侵犯版权的前提下,以视频方式呈现给大家。 二、本课程的理念 一项事业一定有它的理想。程序设计的理想当然是能够完成伟大软件作品。 我们虽然都在现实中不得不做出一些妥协,但理想总是唯一能够激发我们最大创造力的催化剂,它同样是带给我们最大快乐的源泉。我们也许在不断降低曾经的理想维度,但我们也同时都在人生每一个寂静时刻扪心自问深刻反省。那些对我们自己灵魂发出的询问,就是我们不屈服的个性展示。换句话说,面对理想时,我们自始自终都有来自内在天赋的支持。 当然,除了我们的天赋,为了理想,我们同样需要付出巨大的劳动。这些劳动不仅仅是学习和研发过程的坚持,更多的还是抵御外在环境对我们理想意想不到的干扰。其实,无论是否有那些干扰,在外人看来艰辛的劳动对于拥有理想的我们永远是最大的快乐。 对于程序设计来说,我个人伴着理想和辛勤劳动走了很长的路。即使如此,我只能说我对程序设计略知一二,甚至对做出高质量程序的解决之道还有些迷惑了。但我的这些付出,至少使我坚信没有任何灵丹妙药可以实现所谓“在零基础上几日登天”,我也不认为这样做程序的人真正快乐。事实上,理想只离这种模式的程序设计更远。 三、我的经验 作为本课程的主讲者,我应该具备一些基本素质。我希望我的经验能够得到各位的认可。 我现有程序代码量达到1,300,000行,其中Java有950,000行,其他语言有350,000行。至少,我在我的人际圈内没有发现超过这个数目的人。 此时此刻,我还在进行两个重要软件项目的研发。第一个是《新万维网》。它是对传统万维网(WWW)的重大改进。当前版本持续开发超过十年,基础层已经建立,我正在努力修改新版界面。我认为这个产品在学术和市场两个方面都有很好前景。这个项目现在拥有代码行数882,224。从这个角度看,很可能是我国学界最大的软件研究项目。 另一个项目是《GreatFree: 面向互联网环境的通用分布式程序设计技术》。通过我的大量对比,这是国际学界在互联网环境下第一个具备通用开发能力的程序设计技术。尽我所知,我国在程序设计领域的贡献很少,我的这个成果具备首创价值。我正在把它以新的语言形式展现出来。这应该是我国在计算机领域贡献的第一个程序设计语言。现有成果已经开源,大家可以从GitHub上找到,链接是:http://github.com/greatfree/wind。 我当前还在大学任教。我在国际知名企业也有一些工作和实习经验。我曾经工作和实习过的机构包括:北京大学、西安工业大学、IBM研究中心(纽约)和贝尔实验室(北京)等。我还曾在美国亚利桑那州立大学获得过计算机科学博士学位。 四、英文问题 本课程的教材和幻灯片全部使用英文。英文是科技领域的官方语言,所有最新科技成果都是以英文方式呈现的。随着互联网技术的广泛普及,通过网络我们可以轻易获得足够多的英文资料。这对提高我们的程序设计技术和能力有极大帮助。另外,我认为当前大学普遍存在专业教育和英文教育割裂的现象,这是非常荒唐的。对于母语非英文的人来说,通过英文学习专业是掌握英文最佳甚至是唯一可行的学习方式。英文对于程序设计的帮助是决定性的。寻找一个编程中具体问题的答案,英文搜索结果要远好于中文。对于程序设计人员,英文还有更特别的意义,毕竟程序是英文写的。英文差,完全导致程序质量大幅下降。最后,我着重需要强调的是,英文能够培养一个人科学理性的思维能力,对提高程序质量有着潜移默化的推动作用。 我多年在大学的教学中一直采取以英文学习专业的方式。实践告诉我,这种方式是成功的,普遍受到学生欢迎。我在我任教过的大学总是最受欢迎的老师之一,这和我的英文教学方式分不开。另外,在我的视频课程中,我对每一张幻灯片都有详细的中文口语解释和大量的程序示例。我认为英文不仅不影响学习质量,反而促进对具体程序设计技术的理解,毕竟英文更能反映出技术的本质。相比于大量不精确的翻译书籍,我认为直接学习英文原著是最好的选择。与此同时,借助视频技术实现音像并茂,可以生动展示英文教学内容,一定对提高学习者能力有本质上的提高。我认为大家是欢迎这种模式的。英文不是学习科技的障碍,恰恰相反,它是我们通向科技巅峰的桥梁。 五、可能的学习者 《Core Java》这本书虽然讨论的是基础Java技术,但它翔实全面的风格其实对每一个对程序设计技术感兴趣专业和非专业人士都有价值。 第一,没有任何程序设计经验的初学者。相比于其他主流语言,Java是经过长期演化后形成的程序设计技术。Java彻底摆脱了早期机器语言的影响,不存在任何对于机器特征过分依赖的编程方式;Java和互联网技术结合得更加紧密,适合学习者初步掌握互联网开发技术;Java采用面向对象程序设计风格,这是当前被普遍接受和推荐的程序设计理念;还有,相比于其他语言,Java的程序呈现方式更加简化。正是由于上述原因,Java是初学者学习程序设计的恰当选择。 第二,需要全面了解Java技术的程序设计人员。根据我的经验,一个程序员完全掌握一门程序设计语言的所有细节是非常困难的,一般都存在对某个分支或者部分细节缺乏了解的现象。本课程的全面性帮助程序员查漏补缺,以较小代价对模糊不清的枝节问题进行了解,从而完善自身的程序设计技术,并迅速在实际研发过程中将所学体现出来。 第三,致力于从事基础软件系统开发的Java程序设计人员。本课程讲授的Java标准版是Java最重要的技术。事实上,Java所有的开发能力集中体现在标准版当中,而非其他任何版本(如Java Enterprise Edition – JEE),更不是其他众多架构(Frameworks)所能代替的。在实际开发中,由于Java标准版一些主要技术使用难度相对较大,很多开发人员有意回避使用它,转而去借助各种架构进行开发,从而快速完成应用软件的建立。从软件工程角度看,这种做法无可厚非。这些架构不要求研发人员具备深厚的基础知识和技能,只需通过简单配置或者简化的脚本语言编程就可以完成高层应用软件开发。但是长此以往,这种做法逐渐降低程序设计人员的技术能力。只通过架构开发应用的研发人员大都失去开发复杂基础软件系统的能力。本课程讲授的Java标准版是Java核心技术,对这个技术的全面掌握是开发基础软件系统不可或缺的。 六、怎样掌握Java程序设计技术 事实上,我不认为只通过这个课程就可以真正掌握Java程序设计技术。这个认识对任何程序设计技术课程都是成立。作为一门需要高度实践经验的科学技术,程序设计课程或者书籍只能是辅助的和启发式的。我认为无论使用何种开发技术何种开发理念,真正决定程序质量的永远是人,而不是单独的某项技术。对于一个高水平的程序设计师来说,他完全可以使用相对落后的技术做出高质量的软件;而低水平的程序设计人员,无论使用任何先进工具都无法保证程序水准。因此,我在课堂上经常和学生们说,你们要坚持“每天编程序”。更重要的是,这个程序应该学生独立思考后设想出的一个软件,每天坚持逐步把它做出来。当这个软件达到特定规模时,设计者才真正领悟到程序设计的核心价值、各种技术的科学理性意义乃至程序设计的乐趣。 最后,除了“每天编程序”,其实我在课堂上对学生还有一个建议,就是“每天读英文”。前两天,我在网上看到一篇文章。它展示了钱学森先生1933年6月在国立交通大学读书时参加《水力学》考试的试卷。我惊讶地发现这份试卷完全是英文作答。这意味着在遥远的八十八年前,我国大学已经开始使用英文进行专业教育了。遗憾的是,在当前我国主要大学里,竟然还做不到这点。我希望大家能够理解我对英文学习重要性的一再重复:在我们这个全新时代,在一个富有朝气的学科中以英文为蓝本展开自己的理想!  

50,527

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧