c语言实战开发(进制转换?拉倒吧)2019-11-22 Day6

烧脑的进制转换小demo,唉,你准备好了吗?反正我没有。内容

1:for循环和while循环的选择2:小demo的书写3:数组与小demo

一.for循环和while的选择

如果做一件事情 很关心次数 则最好用for 而while循环不关心次数,也不关心第几次,只关心条件成不成立int i = 1;
while (i < 1){
i++;
}所以while和for其实也可以是相通的

二.小demo:进制转换

首先要了解一下进制转换呀1:首先:进制有二进制,八进制,十进制,十六进制
2:举例:比如十进制的10转到2进制
从2^0开始写下面一堆数(二进制)
128 64 32 16 8 4 2 1 就是 1010 0x2^0 +1x2^1 +0x2^2 +1x2^3
从8^0开始写下面一堆数(八进制)
512 64 8 1 就是 0012 28^0+18^1demo总体思路:
用while实现从终端输入一个数,把它转换成 2进制 8进制 16进制老师的版本(这个实现不了16进制的转换)

#include<stdio.h>
#include<stdlib.h>
int main (){
    int num;//接收用户输入
    printf("请输入数字:");
    scanf("%d",&num); 
    int wei = 1;
    long long sum = 0 ;//要定义为long long型
    int jinzhi = 2;
    while(1){//不知道几次退出时直接写while(1)就可以 等条件满足就退出 
        int yu = num%jinzhi;
        num = num/jinzhi;//注意这一条代码一定要放在上面一条的下面,而不是上面,否则num就提前变化了
        //计算当前位数的值加上之前的值,就是目前的总和 
        sum = sum  + yu*wei;
        wei = wei*10;//注意是位数乘以10而不是+1
        //printf("%d",yu);
        if(num < jinzhi){
            sum = sum +num*wei ;
            break;//这个break有时候会忘了写
        }
    }
    printf("%d\n",sum);
    
    return 0;
}

三.数组

1一定要知道元素的个数,为啥?系统在给数组分配内存空间的时候知道分配多少
2数组的内存 array[0] == *(array +0) 数组访问,注意不能越界。数组名就是数组的首地址。
printf("%p\n",array);
printf("%p\n",&array[0]);
printf("%p\n",&array+0);
这三个打印出来的都是一样的
demo
产生四个随机数,将这个四个随机数放到数组里面,然后输出。

int array[4];
    int temp;
    int i ;
    for(i = 0;i <= 4;i++){
        temp = rand()%9;
        array[i] = temp;
        printf("%d ",array[i]);
        
    }

产生四个不同的随机数(这个贼难)自己在课下重新写的时候,忘了先定义一个变量temp装着随机数

#include<stdio.h>
#include<stdlib.h>
#include<time.h>

    
    
//产生随机数的同时比较是否重复
//如果重复,则重新再产生一个随机数
//如果不重复,就保存进去 
//每次i的值和已经存入数值的元素的数目相等 
int main (void){
    int array[4] = {};//定义数组的时候最好这样写,就是要写{},相当于初始化了,就不会受之前就已经存在的值干扰了 
    srand(time(NULL));
    for(int i = 0;i <= 3;i++){  
        int temp = rand()%5;
        if ( i == 0){
            array[i] = temp;//等于1的时候直接赋值
        } else{
            //判断前面与前面的元素是否相等
            int j = 0;
            for(j = 0;j < i;j++){
                //比较j对应的值和前面的元素是否相同
                if( temp == array[j]){//这里要判断一下,因为当temp!=array[j]的时候,不需要任何操作,所以直接判断当temp == array[j]的时候执行什么操作
                    //重复了,直接break
                     printf("重复了:%d\n",temp);//这条语句是后来加上的,主要是看哪个数重复了
                    break;
                }
            }
             
            if(i == j){//判断是如何出来的,到底是正常出来的呢(j = i)还是重复出来的呢(j < i)如果正常出来,则保存 
                array[i] = temp;
                //printf("%d",array[i]);//不能这样写,因为最起码第一个就没有打印 
            }else{
                //重复了,但是相当于浪费掉了一次i,所以要i--一下
                i--;
            
            }
             
        }
    }
    
   for(int i = 0;i <= 3;i++){
        printf("%d",array[i]);
  }
    
    return 0;
}

总结

今天感觉收获不小的还是进制转换,之前一直懒得学,今天总算学到了,不过十进制转十六进制还是不会,课下需要再自己找视频学,另外,最后数组这个小demo的书写也是很费脑筋的,尤其是又定义了一个变量j,和最后通过判断j和i是否相等来看到底是怎么出来的循环。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值