C#中关于程序功能实现以及对代码选择的思考

   C#中关于程序功能实现以及对代码选择的思考

  接触c#语言只有短短几天时间,想要写出什么高大上的深入性研究文章,估计也是满篇的猜想和一些没有逻辑的推断。截至目前而言,从语言入门知识(大多数程序员的入门仪式——输出“hello,world!”)、数据和数据类型、数据运算、程序功能实现流程和循环、数组和集合这些分块的小知识到将所学知识串联应用,并没有承受太大的困难, 像是在用描述的语言来求解应用题,再通过代码将这些描述的语句表达出来。

  记得开班时做了三道趣味题。第一题是主人运送草、羊和狼过河,狼吃羊,羊吃草,主人看管情况不会发生任何事,一次只能运送一样过河,这道题给我的感觉是用来引导学员思维方式,顺便观察学员是否有一个清晰的思路来分析和解答问题,找到关键点就是羊只能单独存在或者随主人一起,这样就能很好的解决问题。第二题是三个和尚和三个怪物过河,只有一只空船,船一次可以运两人,每当出现怪物数量大于和尚数量,游戏就结束了,这道题也是考验思考问题的方式,但是还要注意怪物和和尚运输流程的正确性,必须保证和尚安全的先全部到达对岸,围绕这个中心来解决问题。第三题印象比较深刻,做完后,旁边的同学说可以27s,然后我就进行了反复的尝试(只能是29s)。要求是利用一盏只能亮30s的灯引导5人过桥,一次只能两人持灯通过,5人所需时间分别为1s、3s、6s、8s、12s当然,这道题要抓住重点,就是尽量将1s小孩用来反方向运灯,而且必须将12s的老人和8s的胖子一趟完成通过,在多次尝试中,我发现只要保证1s的小孩返回两趟,3s小孩返回一趟,耗时最长的两位一次通过,不管其余怎样排序设置,都不会影响到最后的结果。

  回顾一下这个有意义的开课仪式,再回到C#的世界中,其实两者有很多的共同之处,现在就写一下不同代码的同样实现效果这一回事!

 

 

   先举一个简单的例子,在求水仙花数时,需要将一个百位数的每一位的数值进行求解,答案中给出的代码是这样的:

int i = 100;while (i < 1000){    int a = i / 100 % 10;    int b = i / 10 % 10;    int c = i % 10;    if (a * a * a + b * b * b + c * c * c == i)    {        Console.WriteLine(i);    }    i++;}

 

  而我在解答时使用了两种不同的方法,第一种是:

int i = 100;while (i < 1000){    int a = i /100;    int b = i % 10 / 10;    int c = i % 10;    if (a * a * a + b * b * b + c * c * c == i)    {        Console.WriteLine(i);    }    i++;}

 

  第二种方法是:

int i = 100;while (i < 1000){    int a = i / 100;    int b = (i  - a * 100) / 10;    int c = i -a * 100 - b * 10;    if (a * a * a + b * b * b + c * c * c == i)    {        Console.WriteLine(i);    }    i++;}

  以上均是正确的、可实现的代码,代码之所以存在差异,就是在运算时,对问题分析和思考的角度不同。第一种是将所求位数后面的内容抛弃,再将剩余的数对10取余,因为切除后剩余的数的个位总是对应所求位数的值。第二种也是将这个数拆分,将这个数对所求位数的10的倍数求余,将所求位数之前的数全部抛弃,得到的是的第一位总是所求位数的值,再用除法就能得到想要的值。第三种就是个死办法,多余的全减掉再除就可以了。总而言之,不同的思路、不同的解题方法,并不会影响代码的实现,但是选择简短、优雅的代码,能够提高整个代码的美感,这一点还是需要注意。就自己感悟而言,肯定是优先选择自己能够理解的代码,这样用起来才会得心应手,同时可要扩大自己的见识,多想想不同的思路的实现方式。

 

  但是,说到这里,也许有人会有质疑,上面就是一道数学题,和编码的思路有什么关系。那么再来看一下我和其余人不同的实现思路,这个问题是关于建立一个数组并赋值后,让用户输入一个要查找的数字,判断该数字在数组中是否存在。

int[] nums = { 4, 8, 12, 333, -9, 1 };bool isFind = false;for (int i = 0; i < nums.Length; i++){    if (nums[i] == n)    {        isFind = true;        break;    }}if (isFind){    Console.WriteLine("数组中存在该数");}else{    Console.WriteLine("数组中不存在该数");}

 

  我思考的方法是:

int[] nums = { 4, 8, 12, 333, -9, 1 };Console.Write("请输入需要查找的数字:");int input2 = int.Parse(Console.ReadLine());for (int i = 0; i < 5; i++) {   if (nums[i] == input2)       Console.WriteLine("在数组中查找到该数值,该数为数组中的第" + (i + 1) + "项!");   if(i==4&&nums[i]!=input2)       Console.WriteLine("未在数组中找到对应项!"); }

 

  第一种代码是通过定义一个bool类型数据isFind,如果找到,就改变isFind的数据,然后通过isFind的数据完成实现。而我在思考时,是想如果没有找到,那么循环完成后循环次数就会达到最大值,但是此时最后一位数与输入的数相同,两个输出对应条件都能满足,所以,排查到最后并且最后一位的值也不等,才能满足输出未找到结果。通过这样的分析,就写出了这两段代码。这就是不同思路采用不同代码来实现相同功能的方式。

 

  关于不同代码实现相同功能,还有一个最经典的例子,是不能不提的,那就是数组和集合的排序,下面介绍三种思路:交换排序、冒泡排序和选择排序。

  交换排序中心思想是从第一个数组项开始,固定nums[i],依次第i+1个后面的数据进行比较,如果有比num[i]小的值,就对其进行交换。

for( int i = 0; i < arrays.Length - 1;  i++){    for(int  j = i+1; j arrays[j])         {             int temp=arrays[i];             arrays[i]=arrays[j];             arrays[j]=temp;         }   }}

 

  冒泡排序是将最大的数沉到底部,先将最后一个位置固定,再从第一个数开始比较,每遇到一个大的数,这个数就与后一位交换,就像气泡一样,这个变动的寻找中的值越滚越大,直到最后一位。这时,再确定倒数第二位,再次进行替换。(第二个for循环中,每次循环,nums[j]的值总是逐渐变大。)实现代码如下:

 

for(int i = nums.Length - 1; i > 0; i--){    for(int j = 0; j  nums[j+1] )            {               int temp = nums[j];               nums[j] = nums[j+1];               nums[j+1] = temp;            }   }}

 

  选择排序从第一个数开始,先假设第一个数为最小的数,将其与后面每一个数进行比较,如果遇到小的,就记录这个数的下标,循环完成后,记录的下标对应的数一定是数据组的最小值,此时替换最小值到第一位。后面依次循环,完成排序。

for(int i = 0; i < nums.Length - 1; i++){    int index = 1;    for(int j = i+1; j < nums.Length; j++)     {        if(nums[j])<nums[index])           {                index=j;           }     }     int temp = nums[i];     nums[i] = nums[index];     nums[index] = temp;}

  有上面三种排序方法可以看出,只要能够实现功能,思路和代码并不重要。只要能找到解决问题的关键点,并围绕关键点弄懂解决问题的方法,根据方法确定流程,再完成代码的编写,这样想要达到功能的实现并不难。不过为了整个代码的便于查看和修改,在使用这些代码时,在能够理解代码书写的思路前提下,尽量使用结构优良,语句简洁的语句。当然,如果一些方法难以理解,最好还是使用自己理解的代码书写,便于自己完成查看和修改,如果必要,注释也是必不可少。

  总而言之,多观察别人的思路,多看多想多开拓,总是没有坏处。毕竟是编程,难以理解或者使用不熟练,解决的方法还是多练多敲,没有其他的捷径。

以上就是C#中关于程序功能实现以及对代码选择的思考的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1432681.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 08:30:16
下一篇 2025年12月16日 11:49:34

相关推荐

  • .NET支付宝App支付接入的实例分析

    一、前言        最近也是为了新产品忙得起飞,博客都更新的慢了。新产品为了方便用户支付,需要支付宝扫码接入。这活落到了我的身上。产品是Windows系统下的桌面软件,通过软件生成二维码支付。界面以原生的MVVM编写,下面叙述一下基本的过程,做过的老司机可以直接点关闭了。 二、申请接口     …

    好文分享 2025年12月17日
    000
  • C#单例模式的实现以及性能对比的实例

    这篇文章主要介绍了浅谈c#单例模式的实现和性能对比的相关资料,详细的介绍了6种实现方式,需要的朋友可以参考下 简介 单例指的是只能存在一个实例的类(在C#中,更准确的说法是在每个AppDomain之中只能存在一个实例的类,它是软件工程中使用最多的几种模式之一。在第一个使用者创建了这个类的实例之后,其…

    好文分享 2025年12月17日
    000
  • .Net Core之实现下载文件的实例

    本篇将和大家分享的丝.netcore下载文件,常见的下载有两种:a标签直接指向下载文件地址和post或get请求后台输出文件流的方式,本篇也将围绕这两种来分享;如果对您有好的帮助,请多多支持。 允许站点不识别content-type下载文件(即:不受mime类型限制下载) 如何允许下载.nupkg和…

    2025年12月17日 好文分享
    000
  • C# ArrayListd的长度问题解决

    c# arraylistd的长度问题解决 namespace ArrayListd的长度问题{ class Program { static void Main(string[] args) { //需要的参数是object类型 //alt+shift+F10添加引用using System.Col…

    好文分享 2025年12月17日
    000
  • C# 加密类工具实例分析

    5.SHA1加密 //sha1加密 public static String getSha1(String str){ if(str==null||str.length()==0){ return null; } char hexDigits[] = {‘0′,’1′,’2′,’3′,’4’,’5’…

    好文分享 2025年12月17日
    000
  • C#实现杨辉三角的示例

    这篇文章主要介绍了c# 中杨辉三角的实现的相关资料,希望通过本文大家能掌握这部分内容,需要的朋友可以参考下 C# 中杨辉三角的实现 问题描述:创建一个程序来求三角形。该程序提示用户输入数据,然后显示出杨辉三角的规律。            // 输入描述:杨辉三角长,代表数值            …

    好文分享 2025年12月17日
    000
  • C#编写Windows服务程序的图文详解

    本文介绍了如何用c#创建、安装、启动、监控、卸载简单的windows service 的内容步骤和注意事项,需要的朋友可以参考下 一、创建一个Windows Service 1)创建Windows Service项目   2)对Service重命名 将Service1重命名为你服务名称,这里我们命名…

    2025年12月17日 好文分享
    000
  • C#中关于foreach实现的原理详解

    这篇文章主要为大家详细介绍了c#中foreach实现原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文主要记录我在学习C#中foreach遍历原理的心得体会。 对集合中的要素进行遍历是所有编码中经常涉及到的操作,因此大部分编程语言都把此过程写进了语法中,比如C#中的foreach。经常会看…

    好文分享 2025年12月17日
    000
  • C#通过KD树进行距离最近点的查找的实例分析

    这篇文章主要为大家详细介绍了c#通过kd树进行距离最近点的查找,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文首先介绍Kd-Tree的构造方法,然后介绍Kd-Tree的搜索流程及代码实现,最后给出本人利用C#语言实现的二维KD树代码。这也是我自己动手实现的第一个树形的数据结构。理解上难免会有…

    好文分享 2025年12月17日
    000
  • c#如何生成二维码的示例分享

    引用zxing类库 实现功能: 1生成带有Logo二维码 2 将二维码绘制到图片上 3 图片上绘制文字  生成二维码 public string CreateQrCode(string md5Str,string name,int sex) { string str = sex == 1? “先生”…

    好文分享 2025年12月17日
    000
  • C# 数组作为参数传递出现的问题解决

    原则:尽可能控制对数据的修改,如果可以预测某个数据不会或不应该被改变,就要对其控制,而不要期望使用这个数据的调用者不会改变其值。 如果参数在使用过程中被意外修改,将会带来不可预知的结果,而且这种错误很难被检查到,所以我们在设计方法参数的时候,要充分考虑传递引用类型参数或者引用方式传递引用类型参数可能…

    好文分享 2025年12月17日
    000
  • .net core使用Redis发布订阅方法介绍

    本篇文章主要介绍了.net core如何使用redis发布订阅,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 Redis是一个性能非常强劲的内存数据库,它一般是作为缓存来使用,但是他不仅仅可以用来作为缓存,比如著名的分布式框架dubbo就可以用Redis来做服务注册中心…

    2025年12月17日 好文分享
    000
  • 详解.Net Core使用Socket与树莓派进行通信

    这篇文章主要为大家详细介绍了.net core使用socket与树莓派进行通信,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 前言 去年买的树莓派一直放在抽屉里吃灰,前些阵子Debian 9发布,也不出意外的支持了树莓派。 于是重新拿出读卡器又重新了装上了Debian桌面版系统。 介绍 现在这个…

    2025年12月17日
    000
  • C#根据表格偶数与奇数加载不同颜色的实例分析

    这篇文章主要介绍了c# 根据表格偶数、奇数加载不同颜色,需要的朋友可以参考下 效果图:        //偶数随机 Random evenRanm = new Random(); //奇数随机 Random oddRanm = new Random(); string[] listColor = n…

    2025年12月17日
    000
  • C#之FastSocket实战项目的示例分享

    一、FastSocket课程介绍  .net框架虽然微软提供了socket通信的类库,但是还有很多事情要自己处理,比如tcp协议需要处理分包、组包、粘包、维护连接列表等,udp协议需要处理丢包、乱序,而且对于多连接并发,还要自己处理多线程等等。本期分享课程阿笨给大家带来的是来源于github开源so…

    2025年12月17日 好文分享
    000
  • c#之浮点数计算问题的解决

    给大家看个计算题,看看大家的算术能力。 0.1 +0.1 +0.1 – 0.3 等于几? 大家可能会说这么简单的问题,是不是看不起我?肯定等于0啊。 如果大家直接算的是没有问题的,但是如果用计算机呢? 见证奇迹的时刻到了,看代码: void Main(){ var f = 0.1 +0.…

    2025年12月17日
    000
  • C#使用AForge实现摄像头录像功能的案例

    这篇文章主要介绍了c#调用aforge实现摄像头录像的示例代码,非常具有实用价值,需要的朋友可以参考下 1:首先下载库文件>> 也可以去官网寻找>> 下载本教程全代码>> 输出为MP4需要用到ffmpeg相关的文件,我打包的库已经带了,去官网找的库可以在这个目录找…

    2025年12月17日 好文分享
    000
  • C#中关于ActiveMQ的应用详解

    activemq是个好东东,不必多说。activemq提供多种语言支持,如java, c, c++, c#, ruby, perl, python, php等。由于我在windows下开发gui,比较关心c++和c#,其中c#的activemq很简单,apache提供nms(.net messagi…

    好文分享 2025年12月17日
    000
  • .net中关于异步性能测试的示例代码

    很久没有写博客了,今年做的产品公司这两天刚刚开了发布会,稍微清闲下来,想想我们做的产品还有没有性能优化空间,于是想到了.net的异步可以优化性能,但到底能够提升多大的比例呢?恰好有一个朋友正在做各种语言的异步性能测试(有关异步和同步的问题,请参考客《aio与bio接口性能对比》),于是我今天写了一个…

    2025年12月17日 好文分享
    000
  • .NET Core中遇到的一些坑的图文详解

     最近.net core升级到2.0后开始慢慢捣鼓的多了起来,但遇到了不少坑,所以特来记录下。 第一个坑  条件编译符   我们在编写一些方法的时候通常会为Debug模式增加一些输出日志等以便我们检查,也会为Release模式增加或修改一些特定的参数,但今天我在写这些的时候就遇到了这个坑#if !D…

    2025年12月17日 好文分享
    000

发表回复

登录后才能评论
关注微信