Python算法题——国际象棋棋盘(排列组合问题,最小的K个数)

Posted 我不要你觉得

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python算法题——国际象棋棋盘(排列组合问题,最小的K个数)相关的知识,希望对你有一定的参考价值。

  题目一(输出国际象棋棋盘

  分析:

     用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。

   主要代码: 

  for i in range(8):
    for j in range(8):
      if (i+j)%2!=0:
        print(chr(219)*2,end=‘‘)
      else:
        print(‘ ‘,end=‘‘)
    print(‘‘)


  题目二(排列组合问题)

   有1、2、3、4个数字,能组成多少个互不相同且无重复数字的四位数?都是多少?

   分析:

  我们可以先预测一下,共有24种情况。然后,可以用循环嵌套的方法,嵌套四个循环,类似 for a in range(1,5):,使数字在循环中不停变化,组合;再设定类似 a!=b 的判断条件,使其数字不能重复,最后输出符合条件的数字即可。

 主要代码:  

  for a in range(1,5):
    for b in range(1,5):
      for c in range(1,5):
        for d in range(1,5):
          if (a!=b) and (b!=c) and (c!=d) and (d!=a) and (a!=c) and (b!=d):
            print("%d%d%d%d" % (a, b, c, d))

 

  题目三(最小的K个数)

  输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。

  分析:

  首先从键盘输入n个整数(列表输入)和k,然后临近的数字两两进行比较,按照从小到大的顺序进行交换,如果前面的值比后面的大,则交换顺序。这样一趟过去后,最小的数字被交换到了第一位;然后是次小的交换到了第二位,。。。,依次直到第k个数,停止交换。返回lists的前k个数(lists[0:k],前闭后开)。最后将结果再转成字符串输出。

  主要代码:  

  lst = list(input().split(‘,‘))
    def function(lst,k):
      length = len(lst)
      for i in range(k):
        for j in range(i+1,length):
          if lst[i] > lst[j]:
            lst[j],lst[i] = lst[i],lst[j]
      return lst[0:k]
   n=int(input())
  a=(function(lst,n))
  for x in a:
  print(x,end=‘,‘)

  

以上是关于Python算法题——国际象棋棋盘(排列组合问题,最小的K个数)的主要内容,如果未能解决你的问题,请参考以下文章

面试常考算法题---回溯法(学习笔记)

Python 排列组合

opencv:检测棋盘角的最佳方法

回溯算法之N皇后问题

一道算法题-八皇后问题(C++实现)

算法 ---- LeetCode回溯系列问题题解