热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

For循环比预期更早地检测到'\0'

如何解决《For循环比预期更早地检测到'\0'》经验,为你挑选了1个好方法。

根据K&R编写的"C编程语言"一书,您可以通过将'\ 0'写入数组中的最后一个变量来指定字符数组的结尾.在将值写入数组后,我以'\ 0'结束它,就像这样.

void itob(int value, char string[], int base)//writes integer c into string s with a base of b 

{
    int i;
    for (i=0; value; i++) {

        string[i] = value % base; //Writes remainder of value / base to character array
        value = value / base;
    }

    string[++i] = '\0'; // Ends string with EOF

}

那么为什么当我在for循环中打印字符的值时,它会在一次迭代后停止吗?类似地,当我打印整个字符串时,它会在单个值后停止.

int main()
{
    int i = 0;

    char string[MAXLINE]; // Max line defined as 1000
    int value;
    int base; 

    printf("Enter Value ");
    scanf("%d", &value);

    printf("\nEnter Base ");
    scanf("%d", &base);

    itob(value, string, base);

    for (i = 0; string[i] != '\0'; i++) { 
    printf("Char %d = %d\n" , i, string[i]);}

    printf("\n%d in base %d = %s" , value, base, string); 


}

产量

Enter Value 27

Enter Base 5

Char 0 = 2

27 in base 5 is = 

jcarpenter2.. 5

基本上你是混合整数值和char值.在itob您将每个数字存储为数字string[i] = value % base;.对于已知的基数<= 10,该行应更改为string[i] = '0' + value % base.或者对于<= 36,您可以将其更改为两行static char chars[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; string[i] = chars[value % base].无论哪种方式,请确保在继续之前检查基数是否在范围内.

然后,您必须将printf中的第二个%d更改为%c,以表示您正在打印字符.

另请注意,该数字将首先存储为little-endian,最低位数.

编辑:也string[++i] = '\0'改为string[i] = '\0'因为i已经指向所有附加字符后面的索引.



1> jcarpenter2..:

基本上你是混合整数值和char值.在itob您将每个数字存储为数字string[i] = value % base;.对于已知的基数<= 10,该行应更改为string[i] = '0' + value % base.或者对于<= 36,您可以将其更改为两行static char chars[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; string[i] = chars[value % base].无论哪种方式,请确保在继续之前检查基数是否在范围内.

然后,您必须将printf中的第二个%d更改为%c,以表示您正在打印字符.

另请注意,该数字将首先存储为little-endian,最低位数.

编辑:也string[++i] = '\0'改为string[i] = '\0'因为i已经指向所有附加字符后面的索引.


推荐阅读
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了在Java中gt、gtgt、gtgtgt和lt之间的区别。通过解释符号的含义和使用例子,帮助读者理解这些符号在二进制表示和移位操作中的作用。同时,文章还提到了负数的补码表示和移位操作的限制。 ... [详细]
  • 本文介绍了基于c语言的mcs51单片机定时器计数器的应用教程,包括定时器的设置和计数方法,以及中断函数的使用。同时介绍了定时器应用的举例,包括定时器中断函数的编写和频率值的计算方法。主函数中设置了T0模式和T1计数的初值,并开启了T0和T1的中断,最后启动了CPU中断。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
author-avatar
liuluoyu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有