logo

CuriousTab

CuriousTab

Discussion


Home C Programming Arrays Comments

  • Question
  • What will be the output of the program if the array begins 1200 in memory?
    #include<stdio.h>
    
    int main()
    {
        int arr[]={2, 3, 4, 1, 6};
        printf("%u, %u, %u\n", arr, &arr[0], &arr);
        return 0;
    }
    


  • Options
  • A. 1200, 1202, 1204
  • B. 1200, 1200, 1200
  • C. 1200, 1204, 1208
  • D. 1200, 1202, 1200

  • Correct Answer
  • 1200, 1200, 1200 

    Explanation
    Step 1: int arr[]={2, 3, 4, 1, 6}; The variable arr is declared as an integer array and initialized.

    Step 2: printf("%u, %u, %u\n", arr, &arr[0], &arr); Here,

    The base address of the array is 1200.

    => arr, &arr is pointing to the base address of the array arr.

    => &arr[0] is pointing to the address of the first element array arr. (ie. base address)

    Hence the output of the program is 1200, 1200, 1200


    Arrays problems


    Search Results


    • 1. What will be the output of the program if the array begins at 65472 and each integer occupies 2 bytes?
      #include<stdio.h>
      
      int main()
      {
          int a[3][4] = {1, 2, 3, 4, 4, 3, 2, 1, 7, 8, 9, 0};
          printf("%u, %u\n", a+1, &a+1);
          return 0;
      }
      

    • Options
    • A. 65474, 65476
    • B. 65480, 65496
    • C. 65480, 65488
    • D. 65474, 65488
    • Discuss
    • 2. What will be the output of the program?
      #include<stdio.h>
      void fun(int **p);
      
      int main()
      {
          int a[3][4] = {1, 2, 3, 4, 4, 3, 2, 8, 7, 8, 9, 0};
          int *ptr;
          ptr = &a[0][0];
          fun(&ptr);
          return 0;
      }
      void fun(int **p)
      {
          printf("%d\n", **p);
      }
      

    • Options
    • A. 1
    • B. 2
    • C. 3
    • D. 4
    • Discuss
    • 3. What will be the output of the program in Turb C (under DOS)?
      #include<stdio.h>
      
      int main()
      {
          int arr[5], i=0;
          while(i<5)
              arr[i]=++i;
      
          for(i=0; i<5; i++)
              printf("%d, ", arr[i]);
      
          return 0;
      }
      

    • Options
    • A. 1, 2, 3, 4, 5,
    • B. Garbage value, 1, 2, 3, 4,
    • C. 0, 1, 2, 3, 4,
    • D. 2, 3, 4, 5, 6,
    • Discuss
    • 4. What will be the output of the program?
      #include<stdio.h>
      
      int main()
      {
          void fun(int, int[]);
          int arr[] = {1, 2, 3, 4};
          int i;
          fun(4, arr);
          for(i=0; i<4; i++)
              printf("%d,", arr[i]);
          return 0;
      }
      void fun(int n, int arr[])
      {
          int *p=0;
          int i=0;
          while(i++ < n)
              p = &arr[i];
          *p=0;
      }
      

    • Options
    • A. 2, 3, 4, 5
    • B. 1, 2, 3, 4
    • C. 0, 1, 2, 3
    • D. 3, 2, 1 0
    • Discuss
    • 5. What will be the output of the program?
      #include<stdio.h>
      
      int main()
      {
          float arr[] = {12.4, 2.3, 4.5, 6.7};
          printf("%d\n", sizeof(arr)/sizeof(arr[0]));
          return 0;
      }
      

    • Options
    • A. 5
    • B. 4
    • C. 6
    • D. 7
    • Discuss
    • 6. What will be the output of the program?
      #include<stdio.h>
      
      int main()
      {
          int a[5] = {5, 1, 15, 20, 25};
          int i, j, m;
          i = ++a[1];
          j = a[1]++;
          m = a[i++];
          printf("%d, %d, %d", i, j, m);
          return 0;
      }
      

    • Options
    • A. 2, 1, 15
    • B. 1, 2, 5
    • C. 3, 2, 15
    • D. 2, 3, 20
    • Discuss
    • 7. What will be the output of the program?
      #include<stdio.h>
      
      int main()
      {
          int arr[1]={10};
          printf("%d\n", 0[arr]);
          return 0;
      }
      

    • Options
    • A. 1
    • B. 10
    • C. 0
    • D. 6
    • Discuss
    • 8. What will be the output of the program in 16-bit platform (under DOS)?
      #include<stdio.h>
      
      int main()
      {
          struct node
          {
              int data;
              struct node *link;
          };
          struct node *p, *q;
          p = (struct node *) malloc(sizeof(struct node));
          q = (struct node *) malloc(sizeof(struct node));
          printf("%d, %d\n", sizeof(p), sizeof(q));
          return 0;
      }
      

    • Options
    • A. 2, 2
    • B. 8, 8
    • C. 5, 5
    • D. 4, 4
    • Discuss
    • 9. What will be the output of the program?
      #include<stdio.h>
      
      int main()
      {
          union var
          {
              int a, b;
          };
          union var v;
          v.a=10;
          v.b=20;
          printf("%d\n", v.a);
          return 0;
      }
      

    • Options
    • A. 10
    • B. 20
    • C. 30
    • D. 0
    • Discuss
    • 10. What will be the output of the program in 16 bit platform (Turbo C under DOS)?
      #include<stdio.h>
      
      int main()
      {
          struct value
          {
              int bit1:1;
              int bit3:4;
              int bit4:4;
          }bit;
          printf("%d\n", sizeof(bit));
          return 0;
      }
      

    • Options
    • A. 1
    • B. 2
    • C. 4
    • D. 9
    • Discuss


    Comments

    There are no comments.

Enter a new Comment