简单的for循环,你不会就落后了

for

从1~100所有整数的和

#!/bin/bash
sum=0
for i in {1..100}      注意这一行和下面的对比,有in
do
   sum=$[$sum + $i]
done
   echo $sum
#!/bin/bash
sum=0
for ((i=1;i<=100;i++))   注意这一行和上面的对比,没有in
do
   sum=$[$sum + $i]
done
   echo $sum

例1

批量添加用户
用户名存放在users.txt文件中,每行一个
初始密码均设为123456
验证脚本
在这里插入图片描述

[root@localhost ~]#vim user.sh 

#!/bin/bash
user=`cat user.txt`或ULIST=$(cat /root/users.txt)   此处变量$user=文件中user.txt中所有的用户名
for i in $user      这条命令可以从变量$user中逐条提取内容
do
echo $i 
useradd $i &>/dev/null
echo "123456"|passwd --stdin $i &> /dev/null
done

在这里插入图片描述

例2

根据IP地址检查主机状态
IP地址存放在ipadds.txt件中,每行一个
使用ping命令检测各主机的连通性

#!/bin/bash
for a in {1..255}
do
   ping -c 3 -i 0.2 -W 3 "192.168.1.$a" &> /dev/null
   if [ $? -eq 0 ]
   then
      echo "Host 192.168.1.$a is up."
   else
      echo "Host 192.168.1.$a is down."
   fi
done

echo "--------------------"

b=1
while [ $b -le 255 ]
do
   ping -c 3 -i 0.2 -W 3 "192.168.1.$b" &> /dev/null
   if [ $? -eq 0 ]
   then
      echo "Host 192.168.1.$b is up."
   else
      echo "Host 192.168.1.$b is down."
   fi
   let b++   
done
以下是一个简单的实现方式: 1. 初始化OpenGL窗口和视角。 2. 定义小球的初始位置和速度。 3. 定义重力加速度和反弹系数。 4. 在主循环中,每帧更新小球的位置和速度,并检查碰撞。 5. 如果小球与地面碰撞,则反弹并减小速度的一半。 6. 如果小球速度小于一个很小的阈值,则认为小球已经静止,退出循环。 下面是一份Python代码,可以运行在Python 3和PyOpenGL环境下: ``` python import pygame from pygame.locals import * from OpenGL.GL import * from OpenGL.GLU import * # 小球初始位置和速度 x, y, z = 0, 10, 0 vx, vy, vz = 0, -1, 0 # 重力加速度和反弹系数 g = 0.1 e = 0.5 # 初始化OpenGL窗口和视角 pygame.init() display = (800, 600) pygame.display.set_mode(display, DOUBLEBUF|OPENGL) gluPerspective(45, (display[0]/display[1]), 0.1, 50.0) glTranslatef(0.0, 0.0, -20) # 开始主循环 while True: for event in pygame.event.get(): if event.type == pygame.QUIT: pygame.quit() quit() # 更新小球位置和速度 x += vx y += vy z += vz vy += g # 检查与地面碰撞 if y < 1: y = 1 vy = -vy * e vx, vz = vx * e, vz * e # 如果小球速度很小,则认为小球已经静止 if abs(vx) < 0.01 and abs(vy) < 0.01 and abs(vz) < 0.01: break # 清空屏幕并绘制小球 glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT) glColor3f(1.0, 1.0, 1.0) glPushMatrix() glTranslatef(x, y, z) glutSolidSphere(1, 20, 20) glPopMatrix() pygame.display.flip() pygame.time.wait(10) ``` 在这个代码中,我们使用了Pygame库来初始化OpenGL窗口和处理事件。在主循环中,我们每帧更新小球的位置和速度,并检查碰撞。在绘制时,我们使用OpenGL的glutSolidSphere函数来绘制小球。你可以调整代码中的参数,例如小球的初始位置和速度、重力加速度和反弹系数等,来尝试不同的效果。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值