#include<stdio.h>
int main(){
int arr[]={1,2,3,4,5,6,7,8,9,10};
int k=7;
//写一个代码,在arr数组(有序的)中找到7
int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);
for(i=0;i<sz;i++)
{
if(k==arr[i])
{
printf("找到了,下标是:%d\n",i);
break;
}
}
if(i==sz)
printf("找不到\n");
return 0;
}
如果输入k=17
二分查找
#include<stdio.h>
int main(){
int arr[]={1,2,3,4,5,6,7,8,9,10};
int k=7;
int sz=sizeof(arr)/sizeof(arr[0]);//计算元素个数
int left=0;//左下标
int right=sz-1;//右下标
while(left<=right)
{
int mid=(left+right)/2;
if(k<arr[mid])
{
right=mid-1;
}
else if(arr[mid]<k)
{
left=mid+1;
}
else{
printf("找到了,下标是:%d\n",mid);
break;
}
}
if(left>right){
printf("找不到\n");
}
}
k=7
k=17
#include<stdio.h>
#include<string.h>
#include<windows.h>//sleep
#include<stdlib.h>//system
int main() {
char arr1[] = "welcome to bit!!!!!!";
char arr2[] = "#####################";
int left = 0;
int right = strlen(arr1) - 1;
while (left <= right) {
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n", arr2);
// Sleep for one second (1000 milliseconds)
Sleep(1000);
system("cls");
left++;
right--;
}
printf("%s\n",arr2);
return 0;
}
就是一个动画形式,逐渐的展开变成
welcome to bit !!!!!!
#include<stdio.h>
#include<string.h>
int main(){
int i=0;
char password[20]={0};
for(i=0;i<3;i++)
{
printf("请输入密码>");
scanf("%s",password);
if(strcmp(password,"123456")==0){//==不能比较两个字符串是否相等,应该使用一个库函数strcmp
printf("登陆成功\n");
break;
}
else
printf("密码错误\n");
}
if(i==3){
printf("三次密码均错误,退出程序\n");
return 0;
}
}