交叉排列

输入一行 k 个用空格分隔开的整数,依次为 n1, n2 … nk。请将所有下标不能被 3 但可以被 2 整除的数在这些数字原有的位置上进行升序排列,此外,将余下下标能被 3 整除的数在这些数字原有的位置上进行降序排列。

输出包括一行,与输入相对应的若干个整数,为排序后的结果,整数之间用空格分隔。




t = raw_input().split(' ')

n = len(t)
q=[]
p=[]
for k in range(1,n+1):
    if k%3 != 0 and k%2 == 0:
        q.append(t[k-1])    
    elif k%3 == 0:
        p.append(t[k-1])
for x1 in range(0,len(q)):
    q[x1]=int(q[x1])
for y1 in range(0,len(p)):
    p[y1]=int(p[y1])
q1 = sorted(q, reverse=False)
p1 = sorted(p, reverse=True)
for x in range(0,len(p1)):
    t[(x+1)*3-1] = p1[x]
num = 0
for y in range(1,n+1):
    if y%3 != 0 and y%2 == 0:
        t[y-1] = q1[num]
        num += 1
for o in range(0,n):
    t[o] = int(t[o])

    print t[o],


1.没有用到所谓function,纯粹面向过程编程。

2.没有及时将字符转化为int,导致排序时按照字符排,后面纠正。

3.按一行输出 #print XXX,#  在要输出的后加上",",可以按行输出。


问题:

在什么地方可以简单的把输入的字符转化为数字?


### Throwable 类层次结构 Throwable 是 Java 中所有错误与异常的顶级父类,表示程序执行过程中可能出现的非正常情况。此类有两个主要的直接子类:Error 和 Exception[^1]。 然而,关于 prototype bump 交错排列的概念并不属于 Java 异常处理机制的一部分。此术语更常见于前端开发领域中的原型设计模式以及布局算法中。 对于 prototype bump 交错排列的理解可以从以下几个方面展开: #### Prototype Bump 交错排列原理 Prototype bump 交错排列是一种用于优化视觉展示效果的技术,在网格布局或瀑布流布局中有广泛应用。其核心思想是在多列布局中通过调整元素顺序来最小化空白区域,从而提高空间利用率并增强美观度。 - **基本思路**:当新项目加入时,并不简单地按照线性顺序放置到下一行的第一列,而是遍历当前每一列的高度总和,将该项目放入高度最低的那一列底部。 - **实现目标**:确保各列之间的高度差异尽可能小,使得整个页面看起来更加紧凑和谐。 #### 实现方式 以下是使用 JavaScript 结合 HTML/CSS 来模拟这一过程的一个简化版本: ```html <div id="container"></div> <button onclick="addBox()">Add Box</button> <script> function addBox() { const container = document.getElementById('container'); let boxes = Array.from(container.children); // 创建新的盒子元素 var box = document.createElement("div"); box.style.width = '100px'; box.style.height = (Math.random()*150 + 50).toFixed(0)+'px'; // 随机高度 box.style.backgroundColor = `hsl(${Math.random()*360},70%,80%)`; if (!boxes.length) { container.appendChild(box); return; } // 找到最短的一列追加进去 let minIndex = 0; let minHeight = Infinity; for(let i=0;i<boxes.length;i++){ let heightSum = boxes[i].offsetTop + boxes[i].offsetHeight; if(heightSum < minHeight){ minHeight = heightSum; minIndex = i; } } // 插入到指定位置之前 container.insertBefore(box, boxes[minIndex]); } </script> <style> #container{ display:flex; flex-wrap:wrap; gap:10px; } /* 设置容器宽度以控制列数 */ @media screen and (min-width:900px){ #container{width:900px;} } @media screen and (max-width:899px) and (min-width:600px){ #container{width:600px;} } @media screen and (max-width:599px){ #container{width:300px;} } </style> ``` 上述代码片段展示了如何动态创建不同高度的方块,并利用简单的逻辑将其分配给最合适的位置,形成一种近似的交错排列效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值