数据结构与算法分析-C语言描述:习题记录

数据结构与算法分析-C语言描述:习题记录

今天在学习本书第二章的习题部分的时候觉得习题2.7.c比较有意思故作记录,使用语言c#

1.三种算法的程序记录

算法1

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApp3
{
    class Program
    {
        
        const int NUM = 80000;
        static void Main(string[] args)
        {
            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
            stopwatch.Start();
            Console.WriteLine("N is:");
            string N = Console.ReadLine();//输入数据量
            Random random = new Random();//随机生成数据
            int rom = 0;
            int flag = 1;
            int[] nums = new int[NUM];
            for (int i = 0; i < int.Parse(N); i++)
            {
                rom = random.Next(int.Parse(N))+1;
                for (int j = 0; j < i; j++)//算法主体
                {
                    if (nums[j] == rom)
                    {
                        flag = 0;
                    }
                }
                if(flag == 1)
                {
                    nums[i] = rom;
                }
                else
                {
                    flag = 1;
                    i--;
                }

            }
            stopwatch.Stop();
            Console.WriteLine(stopwatch.Elapsed.Minutes + "分" + stopwatch.Elapsed.Seconds + "秒" + stopwatch.Elapsed.Milliseconds + "微秒");
            Console.ReadLine();
        }
    }
}

算法2

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApp4
{
    class Program
    {
        static System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
        const int NUM = 680001;

        static void Main(string[] args)
        {
            
            stopwatch.Start();
            Console.WriteLine("N is:");
            string N = Console.ReadLine();
            Random random = new Random();
            int rom = 0;
            int flag = 1;
            int[] nums = new int[NUM];
            int[] numflag = new int[NUM];
            for (int i = 0; i < int.Parse(N); i++)
            {
                rom = random.Next(int.Parse(N)) + 1;
                if(numflag[rom] != 1)
                {
                    nums[i] = rom;
                    numflag[rom] = 1;
                }
                else
                {
                    i--;
                }

            }
            stopwatch.Stop();
            Console.WriteLine(stopwatch.Elapsed.Minutes + "分" + stopwatch.Elapsed.Seconds + "秒" + stopwatch.Elapsed.Milliseconds + "微秒");

            Console.ReadLine();
        }
    }
}

算法3

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApp5
{
    class Program
    {
        const int NUM = 6400001;
        static void Main(string[] args)
        {
            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
            stopwatch.Start();
            Console.WriteLine("N is:");
            string N = Console.ReadLine();
            Random random = new Random();
            int rom = 0;
            int flag = 1;
            int[] nums = new int[NUM];
            for(int j = 0; j < int.Parse(N); j++)
            {
                nums[j] = j + 1;
            }
            for (int i = 0; i < int.Parse(N); i++)
            {
                rom = random.Next(i);
                int a = nums[i];
                nums[i] = nums[rom];
                nums[rom] = a;

            }
            stopwatch.Stop();
            Console.WriteLine(stopwatch.Elapsed.Minutes + "分" + stopwatch.Elapsed.Seconds + "秒" + stopwatch.Elapsed.Milliseconds + "微秒");
            Console.ReadLine();
        }

运行结果

数量级2000
数据结构与算法分析-C语言描述:习题记录
数量级80000
数据结构与算法分析-C语言描述:习题记录
数量级640000
数据结构与算法分析-C语言描述:习题记录

如有错误,望指出。

上一篇:操作系统基本原理


下一篇:常见的那些模糊不清的概念(长期更新)