求从1到n这n个整数的十进制表示中1出现的次数

/*-------------------------包含头文件------------------------------------*/

#include<stdio.h>

#include<stdlib.h>

#include<malloc.h>

#include<string.h>

int count=0;

/*-------------------------结构体定义部分------------------------------*/

typedef struct Node

{

char name[10];

int score;

struct Node *next;

} ListNode;

/*----------------------------函数声明部分------------------------------*/

/*---------------------------函数实现部分-------------------------------*/

/*-----------------------------创建链表---------------------------------*/

/*在链表的末端插入新的节点,建立链表*/

ListNode *CreateList()

{

ListNode *head;//指向头结点指针

ListNode *p,*pre;

head=(ListNode *)malloc(sizeof(ListNode));//为头节点分配内存空间

head->next=NULL;//将头结点的指针域清空

pre=head;//先将头结点首地址赋给中间变量pre

while(1)

{

if((p=(ListNode *)malloc(sizeof(ListNode)))==NULL)

{

printf("内存空间不足!!!\n");

break;

}

count++;

printf("input name of the %d student(input \"q\" to quit):",count);//打印出第几个人的名字

//内存空间p指向新插入结点的首地址

scanf("%s",&p->name);//输入姓名

if(strcmp(p->name,"q")==0)

break;

printf("input score of the %d student:",count);

scanf("%d",&p->score);//输入分数

pre->next=p;//将p指向新结点插入链表也就是头结点指针域指向

//下个结点

//第一个结点就是p指向的,因为头结点内容为空

pre=p;//这个起着指向下一个结点的作用

pre->next=NULL;

}

return head;//返回这个链表的首地址

}

/*-------------------------输出链表-----------------------------------*/

void PrintList(ListNode *h)

{

ListNode *p;

p=h->next;

while(p)

{

printf("%s,%d",p->name,p->score);

p=p->next;

printf("\n");

}

}

/*----------------------插入链表结点--------------------------*/

/*--------------------------------------------------------------------

函数名称:InsertList(ListNode *h,int i,char name[],int e,int n)

函数功能:插入链表结点

入口参数: h: 头结点地址 i:插入到第几个结点 name:插入结点的姓名 e:插入结点的分数 n:链表中结点的个数除下头结点外的个数

出口参数:

--------------------------------------------------------------------*/

void InsertList(ListNode *h,int i,char name[],int e,int n)

{

ListNode *p,*q;  //先定义2个指向一个结点的指针

if(i<1||i>n+1)

printf("Error!!!\n");

else

{

int j=1;

p=h;//将指针p指向要链表的头结点

while(j<i)

{

p=p->next;

j++;

}

if((q=(ListNode *)malloc(sizeof(ListNode)))==NULL)/*为要插入的

结点分配内存空间*/

printf("内存空间不足!!!\n");

else

{

count++;

strcpy(q->name,name);//将名字拷到要插入的节点内

q->score=e;//将要插入的节点中分数赋值

q->next=p->next;/*这个是将新插入的结点指针域指向

上一个结点指针域指向的结点地址即为p->next*/

p->next=q;/*将要插入结点位置前面的结点指针域

指向现在插入的结点首地址*/

}

}

}

/*--------------------------------------------------------------------

函数名称:DeleteList(ListNode *h, int i, int n)

函数功能:删除链表结点

入口参数: h: 头结点地址 i:要删除的结点所在位置  n:链表中结点的个数除下头结点外的个数

出口参数:

--------------------------------------------------------------------*/

void DeleteList(ListNode *h, int i, int n)

{

ListNode *p,*q;//首先定义2个指向结点型结构体的指针

char name[10];

int score;

if(i<1||i>count+1)

printf("Error!!!\n");

else

{

int j=1;

p=h;//将指针指向链表的头结点首地址

while(j<i)

{

p=p->next;

j++;

}

q=p->next;/*q指向要删除的位置之前的那个结点指针域指向的

地址q指向的结点就是要删除的结点*/

p->next=q->next;/*这个就是将要删除的结点的前面那个结点

的指针域指向要删除的结点指针域中存放的下个结点的

首地址从而实现了删除第i个结点的作用*/

strcpy(name,q->name);

score=q->score;

free(q);//释放q指向的结点

printf("name:%s\tscore:%d has been deleted!!!\n",name,score);

}

}

/*--------------------------主函数-------------------------------*/

int main()

{

ListNode *h;//h指向结构体NODE

int i = 1, n, score;

char name [10];

while ( i )

{

/*输入提示信息*/

printf("1--建立新的链表\n");

printf("2--添加元素\n");

printf("3--删除元素\n");

printf("4--输出当前表中的元素\n");

printf("0--退出\n");

scanf("%d",&i);

switch(i)

{

case 1:

h=CreateList();/*创建链表*/

printf("list elements is : \n");

PrintList(h);

break;

case 2:

printf("input the position. of insert element:");

scanf("%d",&i);

printf("input name of the student:");

scanf("%s",name);

printf("input score of the student:");

scanf("%d",&score);

InsertList(h,i,name,score,count);

printf("list elements is:\n");

PrintList(h);

break;

case 3:

printf("input the position of delete element:");

scanf("%d",&i);

DeleteList(h,i,count);

printf("list elements in : \n");

PrintList(h);

break;

case 4:

printf("list element is : \n");

PrintList(h);

break;

case 0:

return;

break;

default:

printf("ERROR!Try again!\n");

}

}

return 0;

}

求从1到n这n个整数的十进制表示中1出现的次数

时间: 2024-10-13 12:23:34

求从1到n这n个整数的十进制表示中1出现的次数的相关文章

输入一个整数n,求从1到n这n个整数的十进制表示中1出现的次数

题目:输入一个整数n,求从1到n这n个整数的十进制表示中1出现的次数.例如输入12,从1到12这些整数中包含1 的数字有1,10,11和12,1一共出现了5次. 分析:首先最先想到的是遍历从1到n的每个数,判断每个数中包含1的个数,再相加. 时间复杂度:如果输入数字为n,n有O(logn)位,我们需要判断每个数字的每一位是不是为1,所以时间复杂度为O(n*logn).如果输入数字很大的时候,就需要大量的计算,效率不高. 接下来观察规律: 从个位到最高位,我们判断每一位1出现的次数.比如 对于数2

数组中n个数出现次数超过1/(1+n),求这些数

先从<编程之美>2.3节"寻找发帖水王"问题说起. [问题]数组中某个数出现次数超过1/2,求该数. [思路]遍历数组,只要当前的数同临时变量candidate相同,则计数加1,不相同则计数减1,一旦计数为0则临时变量candidate更换成当前的数,继续上述规则.由于某个数出现次数大于一半,则最后临时变量一定保存了该数. /*查找数组中出现一半的数*/ public static int find(int[] candidates) { int candidate=0,t

求一个字符串中连续出现的次数最多的子串

求一个字符串中连续出现的次数最多的子串.例如字符串“abababc”,最多连续出现的为ab,连续出现三次.要和求一个字符串中的最长重复子串区分开来,还是上面的字符串,那么最长的重复子串为abab.两个题目的解法有些类似,都用到了后缀数组这个数据结构.求一个字符串中连续出现的次数最多的子串,首先生成后缀数组例如上面的字符串为:abababcbababcababcbabcabcbcc可以看出第一个后缀数组和第三个后缀数组的起始都为ab,第5个后缀数组也为ab.可以看出规律来,一个字符串s,如果第一次

从1到非负整数n中1出现的次数 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数? 为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次, 但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化, 可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。

/*从1到非负整数n中1出现的次数求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此共出现6次,但是对于后面问题他就没辙了.ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数). */ import java.util.*; public class Class36 { public int NumberOf1Between1A

数字中所有数出现次数为k次,但有一个不为k次,求出这个数

思路: 1.建立辅助数组arr[32],统计数组中数的相应位上1的总和 2.如果要找的数在某个位i上不为0,则arr[i]对k取模肯定为0,否则表示要找的数在此位为1, s  +=  1<<i 代码如下: int find(int *a, int len, int K) { int arr[32] = {0}; int i, j; for(i = 0; i < len; ++i) { unsiged int k = a[i]; -->负数右移补1,会出错,所以先变成unsigned

任意输入一串字符串,求该字符串中字符的出现次数并打印出来,如输入“bcaba”输出:b 2 c 1 a 2

前言:其实我还是有点不懂,有点郁闷了,算了直接把代码放上去把. 方法一: Scanner input=new Scanner(System.in); System.out.println("请输入一个字符"); String str=input.next(); char[] strChar=str.toCharArray(); //声明集合,把之存在集合中 Map<Character,Integer> map=new HashMap<>(); for(int i

算法笔试

1.把二元查找树转变成排序的双向链表 题目:输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表.要求不能创建任何新的结点,只调整指针的指向.   10  / \  6  14 / \ / \4  8 12 16 转换成双向链表4=6=8=10=12=14=16.  首先我们定义的二元查找树 节点的数据结构如下: struct BSTreeNode{  int m_nValue; // value of node  BSTreeNode *m_pLeft; // left child of

剑指offer题目记录

1.如下为类型CMyString的声明,请为该类型添加赋值运算符函数. 2.设计一个类,我们只能生成该类的一个实例.   3.在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否函数该整数.   4.请实现一个函数,把字符串中的每个空格替换成"%20".例如输入"We are happy",则输出"We%20are%20happy".   4_1

数据结构与算法80道

1. 把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表. 要求不能创建任何新的结点,只调整指针的指向. 10 / \ 6 14 / \ / \ 4 8 12 16 转换成双向链表 4=6=8=10=12=14=16. 首先我们定义的二元查找树 节点的数据结构如下: struct BSTreeNode { int m_nValue; // value of node BSTreeNode *m_pLeft; // left child of no